相当于PCRE / etc的Java正则表达式。简写“ \ K”?
Perl
RegEx和PCRE(与Perl兼容的RegEx)等具有简化的功能,\K
可以丢弃除捕获组之外左侧的所有匹配项,但是Java不支持它,那么Java等效于它吗?
回答:
。但是,您始终可以使用 捕获组 重新编写此类模式。
如果仔细研究\K
运算符及其限制,您会发现可以使用 捕获组 替换此模式。
请参阅rexegg.com \K
参考:
在模式中间,
\K
说“将已报告比赛的开始重置到此点”。在\K
未报告之前匹配的任何内容,有点像是在后面。
\K
和后向之间的主要区别在于,在PCRE中,后向不允许您使用量词:寻找的长度必须是固定的。另一方面,\K
可以将其放置在模式中的任何位置,因此您可以在之前随意使用任何量词\K
。
,所有这些都意味着之前的模式\K
仍然 是一个消耗模式 ,即正则表达式引擎将匹配的文本加到匹配值上,并在匹配该模式时 提高其索引
,并且\K
仅从匹配中删除匹配的文本,将索引保持在它是。这意味着\K
没有比捕获组更好的方法了。
因此,value\s*=\s*\K\d+
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演示。
以上是 相当于PCRE / etc的Java正则表达式。简写“ \ K”? 的全部内容, 来源链接: utcz.com/qa/403985.html