Rog*_*ger 5 c++ regex boost match boost-regex
到目前为止,这是我的正则表达式:
^((([a-zA-Z0-9_\/-]+)[ ])+((\bPHONE_NUMBER\b)|(\b(IP|EMAIL)_ADDRESS\b))[ ]*[;]*[ ]*)+$
Run Code Online (Sandbox Code Playgroud)
;
如果我(([a-zA-Z0-9_\/-]+)[ ])+((\bPHONE_NUMBER\b)|(\b(IP|EMAIL)_ADDRESS\b))
在第一个之后找到另一个,我想至少制作一个强制性的.
/tests/phone PHONE_NUMBER ; /tests/IP IP_ADDRESS
应该匹配.
/tests/phone PHONE_NUMBER /tests/IP IP_ADDRESS
不应该匹配.
我怎样才能做到这一点?
是的,你可以这样做。为此使用递归正则表达式。
^(((\s*(([\w_\/-]+)\s)((\bPHONE_NUMBER\b)|(\b(IP|EMAIL)_ADDRESS\b))\s*))(;|$)(?1)*)
Run Code Online (Sandbox Code Playgroud)
https://regex101.com/r/dE2nK2/3
(?1)
是一个递归正则表达式,用于重复组 1 的正则表达式模式。如果您想对整个字符串执行递归正则表达式,请使用(?R)
,但您将无法使用起始锚点^
。(;|$)
匹配的正则表达式应以;
字符串的任一或结尾结尾$
。\s
空格而不是[ ]
.;*
并且[;]*
是相同的。您可以在此处了解有关递归正则表达式的更多信息:http://www.rexegg.com/regex-recursion.html
归档时间: |
|
查看次数: |
80 次 |
最近记录: |