正则表达式

正则表达式修饰符

修饰符描述
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_]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值