没有直接的等价物 。但是,您始终可以使用 捕获组 重新编写此类模式。
如果仔细研究
K运算符及其限制,您会发现可以使用 捕获组 替换此模式。
请参阅rexegg.com
K参考:
在模式中间,
K说“将已报告比赛的开始重置到此点”。在K未报告之前匹配的任何内容,有点像是在后面。K和后向之间的主要区别在于,在PCRE中,后向不允许您使用量词:寻找的长度必须是固定的。另一方面,K可以将其放置在模式中的任何位置,因此您可以在之前随意使用任何量词K。
但是 ,所有这些都意味着之前的模式
K仍然 是一个消耗模式 ,即正则表达式引擎将匹配的文本加到匹配值上,并在匹配该模式时 提高其索引
,并且
K仅从匹配中删除匹配的文本,将索引保持在它是。这意味着
K没有比捕获组更好的方法了。
因此,
values*=s*Kd+PCRE / Onigmo模式将转换为以下Java代码:
String s = "Min value = 5000 km";Matcher m = Pattern.compile("value\s*=\s*(\d+)").matcher(s);if(m.find()) { System.out.println(m.group(1));}
有一个替代方法,但是只能与更小,更简单的模式一起使用。甲约束宽度回顾后:
只要匹配字符串的长度在预定范围内,Java就会在后面的范围内接受量词。例如,
(?<=cats?)之所以有效是因为它只能匹配三个或四个字符的字符串。同样,(?<=A{1,10})是有效的。
因此,这也将起作用:
m = Pattern.compile("(?<=value\s{0,10}=\s{0,10})\d+").matcher(s); if(m.find()) { System.out.println(m.group()); }
请参阅Java演示。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)