必备技能之python正则表达式(二)

声明:本文乃“运维家”原创,转载请注明出处,更多内容请关注公众号“运维家”。

图片

主旨

上一篇文章中我们介绍了python部分常用的正则表达式,这一节我们就看看如何在python中进行使用,这里我们借助re模块来实现。

环境

linux 环境
python3.0+ 环境

PS:如果不知道如何在linux上安装python3.0以上的版本,在公众号“运维家”后台回复“103”,即可获取安装操作手册。

match

match() 函数试图从字符串的起始部分对模式进行匹配。如果匹配成功就返回一个匹配对象;如果匹配失败,就返回none,匹配对象的group()方法能够用于显示那个成功的匹配。

# 成功的匹配-示例1
>>> import re
>>> m = re.match('abc', 'abc')
>>> if m is not None:
...     m.group() 
... 
'abc'
>>> 

# 成功的匹配-示例2
>>> import re
>>> m = re.match('abc', 'abcd')
>>> if m is not None:
...     m.group()
... 
'abc'
>>>


# 失败的匹配
>>> import re   
>>> m = re.match('abc', 'nihaobc')
>>> if m is not None:
...     m.group()
... 
>>>

search

search()的工作方式与match()完全一致,不同之处在于search()会用它的字符串参数,在任意位置对给定正则表达式模式搜索第一次出现的匹配情况。

通过下面的例子可以看出search和match之间的差异

>>> import re
>>> m = re.match('abc', 'oooabcppp')
>>> if m is not None:
...     m.group()
... 
>>> import re
>>> m = re.search('abc', 'oooabcppp')
>>> if m is not None:
...     m.group()
... 
'abc'
>>>

从以上示例中我们可以看到,使用match的时候,是从左边第一个字符进行匹配,所以虽然我们的字符中确实包括了abc字样,但是由于不是左边第一个字符,所以没有匹配到。那么,当我们使用search的时候,他会按照从左往右的顺序,匹配在字符串中第一次出现的位置。

什么意思?你是说如果被匹配的字符串中有多个符合的内容,也只会匹配一个嘛?我们看看下面的示例就明白了。

>>> import re
>>> m = re.search('abc', 'oooabcpppabcd')
>>> if m is not None:
...      m.group()
... 
'abc'
>>>

从上面的示例中我们就知道答案了吧,确实只会匹配第一个。如果匹配到了,就结束了该次匹配。

匹配多个字符串

在上一节中,我们使用正则表达式的择一匹配符,下面我们就演示下如何在python使用该方法。

剩余内容请关注微信公众号 “运维家” ,回复 “105” 查看。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

运维家

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值