Go 中字符串末尾的正则表达式匹配失败

我正在尝试针对以下模式测试一个字符串:“至少一对方括号,包含 2 位数字,后跟至少一个字符”。例如,[11][22][33]dd应该匹配而不应该匹配[11][22][33]

我已经尝试过这个正则表达式:(\[\d{2}])+.+. 然而,当它与 进行测试时[11][22][33],它应该会失败,但它仍然通过了该测试。第一个+量词仅匹配两组[11][22],其余部分[33]匹配.+

我认为量词的“贪婪”行为+会耗尽它所修改的组的所有匹配段;然而,正则表达式引擎似乎会将“耗尽所有匹配可能性”原则置于“贪婪量词”规则之上,而不是我所期望的方式。

我应该如何实现我的目标?

(这个问题实际上与语言无关,尽管标有“golang”,这是我当前使用的语言。)


尚方宝剑之说
浏览 87回答 2
2回答

慕标琳琳

您可以使用re := regexp.MustCompile(`(?:\[\d{2}])+(.*)`)match := re.FindStringSubmatch(s)if len(match) > 1 {    return match[1] != ""}return false该(?:\[\d{2}])+(.*)模式匹配 1+ 次出现[,2 个数字,]然后将除换行符之外的任何 0 个或更多字符捕获到组 1 中。然后,如果找到匹配项 ( if len(match) > 1),true则如果组 1 值不为空,则应返回 ( match[1] != ""),否则false返回。请参阅Go 演示:package mainimport (    "fmt"    "regexp")func main() {    strs := []string{        "[11][22][33]",        "___[11][22][33]",        "[11][22][33]____",        "[11][22]____[33]",    }    for _, str := range strs {        fmt.Printf("%q - %t\n", str, match(str))    }}var re = regexp.MustCompile(`(?:\[\d{2}])+(.*)`)func match(s string) bool {    match := re.FindStringSubmatch(s)    if len(match) > 1 {        return match[1] != ""    }    return false}输出:"[11][22][33]" - false"___[11][22][33]" - false"[11][22][33]____" - true"[11][22]____[33]" - true

白衣非少年

我认为您需要使用的正则表达式是这样的:(\[[0-9]{2}\]){1,}[a-z]{1,}
打开App,查看更多内容
随时随地看视频慕课网APP