正则表达式修饰符
修饰符 | 描述 |
---|---|
re.I | 使匹配对大小写不敏感 |
re.M | 多行匹配,影响^和$ |
re.S | 使.匹配换行符在内的所有字符 |
- re.I示例
import re
a = 'It\'s a white dog. Dogs are smarter animal'
b = re.findall(r'dog',a)
c = re.findall('dog',a,re.I)
print(b)
print(c)
#输出结果
['dog']
['dog', 'Dog']
- re.M示例
#从字符串末尾匹配冒号加一个空格后的数字串,中间有换行符\n,可以用re.M匹配多行
import re
a = 'IF_MIB::=Counter32: 12345\nIF_MIB::=Counter32: 1234556'
b = re.findall( r'(?<=\:\s)\d+$', a)#只匹配整个字符串的尾部
c = re.findall( r'(?<=\:\s)\d+$', a, re.M)#以换行符为一个字符串的尾部
print(b)
print(c)
#输出结果
['1234556']
['12345', '1234556']
- re.S示例
>>>print(re.match('Hello.', 'Hello\nWorld'))
None
>>>print(re.match('Hello.', 'Hello\nWorld', re.S))
<_sre.SRE_Match object; span=(0, 6), match='Hello\n'>
正则表达式函数
re.match函数
尝试从一个字符串的起始位置匹配一个模式,匹配成功返回匹配对象,否则返回None。
- 函数语法
re.match(pattern,string,flags=0) - 参数说明
正则表达式模式
(?i:re)示例,正则表达式包含可选标志i,即忽略大小写
>>> a = 'saxsaWDMdDsJnkdjncj'
>>> re.search(r'M(?i:dd)sj',a)
None
>>> re.search(r'M(?i:ddsj)',a)
<re.Match object; span=(7, 12), match='MdDsJ'>
- 正则表达式特殊元素
模式 | 描述 |
---|---|
\d | 匹配一个数字字符,等价于[0-9] |
\D | 匹配一个非数字字符,等价于[^0-9] |
\s | 匹配任何空白字符,包括空格、制表符、换页符等,等价于 [ \f\n\r\t\v] |
\S | 匹配任何非空白字符,等价于 [ ^\f\n\r\t\v] |
\w | 匹配包括下划线的任何单词字符,等价于[A-Za-z0-9_] |
\W | 匹配任何非单词字符,等价[^A-Za-z0-9_] |