正则表达式之排除型字符组

前端之家收集整理的这篇文章主要介绍了正则表达式之排除型字符组前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

在方括号[....]中列出希望匹配的所有字符,这种字符组叫做"普通字符组".

假定给定一个由两个字符构成的字符串str,要判断这两个字符串是否都是数字字符,可以使用[0-9][0-9],但如果要求判断这个字符串是不是第一个字符不是字符,

第二个是数字字符。这应该怎么做呢?数字的匹配很好处理,用[0-9]即可;但"不是数字"则不好办,因为不是数字的字符太多,不可能使用普通字符组来一一列出来,因此

此时使用普通字符组不行,这是就可以使用排除型字符组.

排除型字符组非常类似普通字符组[...],只是在开方括号[之后紧跟一个脱字符^,即写作[^....],表示"在当前位置,匹配一个没有列出的字符 "。

所以要想表示不是数字的字符(非数字字符),可以使用[^0-9]。

综上,使用[^0-9][0-9]就可以解决匹配第一个不是数字字符,第二个是数字字符的字符串了。如:

re.search(r"^[^0-9][0-9]$","A8")!=None #=>True


在排除型字符组中,如果需要表示匹配横线字符-(而不是用于"范围表示法"),那么横线-应紧跟在^之后;

而在普通字符组中,作为普通字符的横线-应紧跟在开方括号之后.

如匹配一个-、0、9之外的字符

re.search(r"^[^-09]$","3") #=>True

原文链接:https://www.f2er.com/regex/361368.html

猜你在找的正则表达式相关文章