我有一个这样的字符串:
REFORMAT FIELDS=(F1:%[VER#,SAH#]%,%SAH#%,F2:%KMSTAND%)
我正在尝试使用以下正则表达式来获取“F1:”之后的所有字符,直到“F2”:
(F1|F2):(.*?)(?:(?=,F))
它匹配第一部分但它也应该得到第二部分。因此,前瞻功能仅可选。怎么了?
修改 我的代码:
Matcher fields = Pattern.compile("(F1|F2):(.*?)(?:(?=,F))").matcher(line);
while (fields.find()) {
//do something with fields.group(2)
}
答案 0 :(得分:2)
这样前瞻功能只能是可选的。怎么了?
可选的前瞻将毫无用处。在您的情况下,您希望在匹配F2之后前瞻 - 只有您不会注意,F
,而是查找字符串结尾。
将您的模式更改为
(F1|F2):(.*?)(?=,F|\)) // "(F1|F2):(.*?)(?=,F|\\))" with double-escaped brace
// maybe:
(F\d):(.*?)(?=,F\d|\))
或
(F1|F2):(.*?)(?:$|(?=,F))
如果要包括右括号