任何字符串都可以在斜线之间,但必须只有 3 个分区。例如,应该匹配的值:“90/90/90/9090”“FDSAFDSA/90/pppppaA3/9090”不应匹配的值:“90/90/90/9090/90”“FDSAFDSA/90/pppppaA3/9090/90”我正在使用 python 和 re 库,我尝试了很多组合,但没有一个起作用: bool(re.match(r'^.*\/.*\/.*\/((?!\/).)*$', "90/90/90/9090/90")) bool(re.match(r'^.*\/.*\/.*\/((?!/).)*$', "90/90/90/9090/90")) bool(re.match(r'^.*\/.*\/.*\/(?!(/)$).*$', "90/90/90/9090/90")) bool(re.match(r'^.*\/.*\/.*\/(/).*$', "90/90/90/90/90")) bool(re.match(r'^.*\/.*\/.*\/.*(\/)$', "90/90/90/90/90"))
1 回答

元芳怎么了
TA贡献1798条经验 获得超7个赞
你应该使用否定字符类:
^[^/]*/[^/]*/[^/]*/[^/]*$
[^/]
匹配除 之外的任何字符/
,因此我们表示一个包含三个/
及其周围的任何其他字符的字符串。
在您的正则表达式中,.
可以匹配任何内容,包括/
,并且虽然您可以使用否定的环顾四周来近似否定字符类,但您没有正确地将它们应用于.
您拥有的每个 :^((?!\/).)*\/((?!\/).)*\/((?!\/).)*\/((?!\/).)*$
也会起作用,尽管它会降低性能.
并且没有必要逃避那些/
,它们不是正则表达式元字符。您可能需要使用/
用作分隔符的语言或工具对它们进行转义,例如 JavaScript 的/pattern/
语法或 sed 的s/search/replace/
替换。
添加回答
举报
0/150
提交
取消