3 回答

TA贡献1744条经验 获得超4个赞
你所要求的不能用真正的正则表达式来完成,你需要的是(不规则的)反向引用。虽然许多正则表达式引擎实现了它们,但 Go 使用的 RE2 没有。RE2 是一个快速的正则表达式引擎,可以保证线性时间字符串处理,但是没有已知的方法可以以这种效率实现反向引用。(有关更多信息,请参阅https://swtch.com/~rsc/regexp/。)
要解决您的问题,您可能需要搜索其他一些正则表达式库。我相信可以找到 PCRE 的绑定,但我没有个人经验。
另一种方法是在不使用 (ir) 正则表达式的情况下手动解析字符串。

TA贡献1946条经验 获得超4个赞
由于上述问题,我最终确定了以下非正则表达式解决方案:
norm = "this it a ttttt"
repeatCount := 1
thresh := 3
lastChar := ""
for _, r := range norm {
c := string(r)
if c == lastChar {
repeatCount++
if repeatCount == thresh {
break
}
} else {
repeatCount = 1
}
lastChar = c
}

TA贡献1891条经验 获得超3个赞
这是丑陋的解决方案,您可以自动生成它:
A{3,}|B{3,}|...|Z{3,}|a{3,}|b{3,}|...|z{3,}|0{3,}|1{3,}|...|9{3,}
- 3 回答
- 0 关注
- 257 浏览
添加回答
举报