Python基础学习篇-4-常用的正则表达式处理函数

一、re.match函数1、re.match 尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match()就返回none。函数语法:re.match(pattern, string, flags=0)函数参数说明:参数描述pattern匹配的正则表达式string要匹配的字符串。flags标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。参见本文下面附录内...
摘要由CSDN通过智能技术生成



一、re.match函数

1、re.match 尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match()就返回none。

函数语法

re.match(pattern, string, flags=0)

函数参数说明:

参数 描述
pattern 匹配的正则表达式
string 要匹配的字符串。
flags 标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。参见本文下面附录内容

匹配成功re.match方法返回一个匹配的对象,否则返回None。


实例1

>>> import re
>>> str1 = 'abcdefg12345'
>>> print(re.match('abc', str1))   # 在起始位置匹配成功,返回匹配成功的对象
<_sre.SRE_Match object; span=(0, 3), match='abc'>
>>> 
>>> print(re.match('123', str1))    # 没有在起始位置匹配成功,返回none
None
>>> 
>>> print(re,match('890', str1))    # 没有在起始位置匹配成功,返回none
None


2、使用group(num) 或 groups() 匹配对象函数来获取匹配结果

匹配对象方法 描述
group(num=0) 匹配的整个表达式的字符串,group() 可以一次输入多个组号,在这种情况下它将返回一个包含那些组所对应值的元组。
groups() 返回一个包含所有小组字符串的元组,从 1 到 所含的小组号。

实例2

import re
>>> line = 'cats are smarter than dogs'
>>> matchobj = re.match('(.*) are (.*?) .*', line, re.M|re.I)
>>> if matchobj:
print("obj.group(): ", matchobj.group())
print("obj.group(1): ", matchobj.group(1))
print("obj.group(2): ", matchobj.group(2))


obj.group():  cats are smarter than dogs
obj.group(1):  cats
obj.group(2):  smarter

>>> print("obj.groups: ", matchobj.groups())   #返回所有匹配结果的元组
obj.groups:  ('cats', 'smarter')
>>> print("obj.group(3): ", matchobj.group(3))
Traceback (most recent call last):
  File "<pyshell#17>", line 1, in <module>
    print("obj.group(3): ", matchobj.group(3))
IndexError: no such group

>>> 
解析正则表达式:'(.*) are (.*?) .*'
  •   (.*) 第一个匹配分组,.代表匹配除换行符之外的所有字符。
  •  (.*?) 第二个匹配分组,.*? 后面多个问号,代表非贪婪模式,也就是说只匹配符合条件的最少字符
  •  后面的一个 .* 没有括号包围,所以不是分组,匹配效果和第一个一样,但是不计入匹配结果中。

matchObj.group() 等同于 matchObj.group(0),表示匹配到的完整文本字符

matchObj.group(1) 得到第一组匹配结果,也就是(.*)匹配到的

matchObj.group(2) 得到第二组匹配结果,也就是(.*?)匹配到的

因为只有匹配结果中只有两组,所以如果填 3 时会报错。


二、re.search方法

1、re.search 扫描整个字符串并返回第一个成功的匹配。

函数语法:

re.search(pattern, string, flags=0)

函数参数说明:

参数 描述
pattern 匹配的正则表达式
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值