为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

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

2 回答

?
慕标琳琳

TA贡献1830条经验 获得超9个赞

您可以使用


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 main


import (

    "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


查看完整回答
反对 回复 2023-07-17
?
白衣非少年

TA贡献1155条经验 获得超0个赞

我认为您需要使用的正则表达式是这样的:

(\[[0-9]{2}\]){1,}[a-z]{1,}


查看完整回答
反对 回复 2023-07-17
  • 2 回答
  • 0 关注
  • 126 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信