#! /usr/bin/env python
import re
token_re = re.compile(r'use\s+([a-z0-9]+)\s+code', re.IGNORECASE)
def find_token(s):
m = token_re.search(s)
if m is not None:
token = m.group(1)
if token.isupper():
return token
if __name__ == '__main__':
for s in ['Use HELLO1 code',
'USE hello1 CODE',
'this does not match',
]:
print s, '->',
print find_token(s)
下面是程序的输出:
Use HELLO1 code -> HELLO1
USE hello1 CODE -> None
this does not match -> None
3条答案
按热度按时间bmp9r5qi1#
从python 3.6开始,你可以在组中使用flag:
(?imsx-imsx:...)
(Zero或来自集合‘i’、‘m’、‘s’、‘x’的一个或多个字母,可选地后跟‘-’,后跟来自同一集合的一个或多个字母。)re.I(忽略大小写)、re.M(多行)、re.S(点匹配所有)和re.X(冗长),用于表达式的一部分。
因此,
(?i:use)
现在是一个正确的语法。从python3.6终端:qq24tv8q2#
据我所知,python正则表达式引擎不支持partial ignore-case。这里有一个使用大小写不敏感的正则表达式的解决方案,然后测试令牌是否为大写。
下面是程序的输出:
btqmn9zl3#
According to the docs,这是不可能的。
(?x)
语法只允许你修改整个表达式的标志。因此,你必须把它分成三个regexp,然后一个接一个地应用它们 * 或者 * 手动执行“忽略大小写”:/[uU][sS][eE]...