Go 正規表示式中的負匹配
在 Go在正規表示式中,由於缺乏環視構造,因此匹配除特定常數字串之外的所有內容可能具有挑戰性.
原創RegExp:
提供的正規表達式/.*/.*/(.*) 符合三個反斜線之後的所有內容。但是,它不排除包含“somestring”的字串。
否定方法
方法1:Web服務
一解決方法涉及使用產生POSIX 相容否定模式的Web 服務。對於“somestring”,這會產生一個複雜的模式,可以替換為原始正則表達式:
/[^/]*/[^/]*/^([^s]|s(s|o(s|m(s|es(omes)*(s|t(s|r(s|i(s|ns)))|o(s|ms)))))*([^os]|o([^ms]|m([^es]|e([^s]|s(omes)*([^ost]|t([^rs]|r([^is]|i([^ns]|n[^gs])))|o([^ms]|m([^es]|e[^s]))))))))*(s(s|o(s|m(s|es(omes)*(s|t(s|r(s|i(s|ns)))|o(s|ms)))))*(o((me?)?|mes(omes)*(t(r?|rin?)|o(me?)?)?))?)?$
方法2:字符類
而不是使用.* ,以下表達式使用否定字元類[^/]:
`[^/]+/[^/]+/(.*)`
這與第三個之前的任何內容匹配反斜杠,但它不排除帶有“somestring”的字符串。
使用捕獲組的解決方法
由於RE2(Go 使用的)不支援前瞻,我們可以捕獲字串的所有三個部分,並檢查捕獲組提取的值:
import ( "fmt" "regexp" ) func main() { s := "anything/anything/somestring" r := regexp.MustCompile(`^[^/]+/[^/]+/(.*)`) val := r.FindStringSubmatch(s) if len(val) > 1 && val[1] != "somestring" { fmt.Println(val[1]) } else { fmt.Println("No match") } }
此方法捕獲匹配的值並在它們與“somestring”不匹配時打印它們。
以上是如何在沒有 Lookaround 的情況下有效地在 Go 正規表示式中進行負匹配?的詳細內容。更多資訊請關注PHP中文網其他相關文章!