在方括号[....]中列出希望匹配的所有字符,这种字符组叫做"普通字符组".
假定给定一个由两个字符构成的字符串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