我正在尝试针对以下模式测试一个字符串:“至少一对方括号,包含 2 位数字,后跟至少一个字符”。例如,[11][22][33]dd
应该匹配而不应该匹配[11][22][33]
。
我已经尝试过这个正则表达式:(\[\d{2}])+.+
. 然而,当它与 进行测试时[11][22][33]
,它应该会失败,但它仍然通过了该测试。第一个+
量词仅匹配两组[11]
和[22]
,其余部分[33]
匹配.+
。
我认为量词的“贪婪”行为+
会耗尽它所修改的组的所有匹配段;然而,正则表达式引擎似乎会将“耗尽所有匹配可能性”原则置于“贪婪量词”规则之上,而不是我所期望的方式。
我应该如何实现我的目标?
(这个问题实际上与语言无关,尽管标有“golang”,这是我当前使用的语言。)
慕标琳琳
白衣非少年
相关分类