1

假设我有一个合法字符的正则表达式

legals = re.compile("[abc]")

我可以在这样的字符串中返回合法字符列表:

finder = re.finditer(legals, "abcdefg")
[match.group() for match in finder]
>>>['a', 'b', 'c']

如何使用正则表达式查找不在正则表达式中的字符列表?IE 在我的情况下它会返回

['d','e','f','g']

编辑:澄清一下,我希望找到一种方法来做到这一点,而无需修改正则表达式本身。

4

1 回答 1

6

否定字符类:

>>> illegals = re.compile("[^abc]")
>>> finder = re.finditer(illegals, "abcdefg")
>>> [match.group() for match in finder]
['d', 'e', 'f', 'g']

如果你不能这样做(而且你只处理一个字符长度的匹配),你可以

>>> legals = re.compile("[abc]")
>>> remains = legals.sub("", "abcdefg")
>>> [char for char in remains]
['d', 'e', 'f', 'g']
于 2013-07-31T19:24:39.617 回答