在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
Python正则表达式是简介表达一组字符串的表达式,正则表达式可以方便的检查一个字符串是否与某种模式匹配。本文将结合实例给大家讲解六种在正则表达式中的常见函数,分别是re.match、re.search、re.findall、re.compile、re.split和re.sub。
re.match() tch函数从头开始匹配,如果不是起始位置匹配成功的话,match函数的匹配结果就为none。
re.search() 整个字符串,并返回第一个成功的匹配
re.findall() 整个字符串,返回一个list(最常用的)
re.compile() #compile 函数用于编译正则表达式,生成一个正则表达式( Pattern )对象
re.split() #将一个字符串按照正则表达式匹配的结果进行分割,返回列表类型
re.sub() #在一个字符串中替换所有匹配正则表达式的子串,返回替换后的字符串
1、re.match函数
match函数从头开始匹配,如果不是起始位置匹配成功的话,match函数的匹配结果就为none。匹配成功,re.match方法返回一个匹配的对象。
语法如下:re.match(pattern, string, flags=0)
pattern:需要匹配的正则表达式;
string:在那个字符串中就行匹配 ;
flags:标志位(默认为0),它可以控制正则表达式的匹配方式
常见的flags如下:
re.I 忽略匹配时的大小写
re.M 多行匹配,影响 ^ 和 $
re.S . 默认不匹配换行,使 . 匹配包括换行在内的所有字符
re.U 根据Unicode字符集解析字符。这个标志影响 \w, \W, \b, \B
示例如下:
我们可以看出,match函数匹配成功的话,re.match方法返回一个匹配的对象,而不是匹配的正则表达式;通过span()可以获取匹配的位置。
>>> import re
>>> astr='11you are 3344 my apple\n 11开心果,you\n66a77'
>>> re.match('11',astr)
<_sre.SRE_Match object; span=(0, 2), match='11'>
>>> re.match('11',astr).span()
(0, 2)
>>> print(re.match('you',astr))
None
2、re.search函数
搜索整个字符串,并返回第一个成功的匹配。
语法如下:re.search(pattern, string, flags=0)
pattern:需要匹配的正则表达式;
string:在那个字符串中就行匹配 ;
flags:标志位(默认为0),它可以控制正则表达式的匹配方式
常见的flags如下:
re.I 忽略匹配时的大小写
re.M 多行匹配,影响 ^ 和 $
re.S . 默认不匹配换行,使 . 匹配包括换行在内的所有字符
re.U 根据Unicode字符集解析字符。这个标志影响 \w, \W, \b, \B
示例如下:
我们可以看出,search函数匹配成功的话,re.search方法返回一个匹配的对象,而不是匹配的正则表达式;通过span()可以获取匹配的位置。如果没有匹配到,则返回为None。
>>> import re
>>> astr='11you are 3344 my apple\n 11开心果,you\n66a77'
>>> re.search('11',astr)
<_sre.SRE_Match object; span=(0, 2), match='11'>
>>> re.search('you',astr)
<_sre.SRE_Match object; span=(2, 5), match='you'>
>>> re.search('you',astr).span() #通过span()获取匹配的位置
(2, 5)
>>> re.search('11',astr).span()
(0, 2)
>>> print(re.search('22',astr))
None
3、re.findall函数
搜索整个字符串,返回一个list
语法如下:re.findall(string)
>>> import re
>>> astr='1you are 3344 my apple\n 11开心果,you\n66a77'
>>> re.findall('\d\d',astr) #列表形式显示所有的两个数字
['33', '44', '11', '66', '77']
>>> re.findall('\d{2,4}',astr) #列表形式显示所有的2——4个数字,默认贪婪匹配
['3344', '11', '66', '77']
>>> re.findall('\d+',astr) #(1,无穷)
['1', '3344', '11', '66', '77']
>>> re.findall('\d*',astr) #(0,无穷)
['1', '', '', '', '', '', '', '', '', '3344', '', '', '', '', '', '', '', '', '', '', '', '11', '', '', '', '', '', '', '', '', '66', '', '77', '']
>>> re.findall('\d?',astr) #匹配0或1
['1', '', '', '', '', '', '', '', '', '3', '3', '4', '4', '', '', '', '', '', '', '', '', '', '', '', '1', '1', '', '', '', '', '', '', '', '', '6', '6', '', '7', '7', '']
>>> re.findall('\d{2,3}?',astr) #一个模式后跟?,不贪婪匹配,范围后面?,有两次就先取两次
['33', '44', '11', '66', '77']
>>> re.findall('\d.\d',astr) #匹配两个数字与中间任意字符
['334', '6a7']
>>> re.findall('^\d',astr) #以数字开头
['1']
>>> re.findall('^\d',astr,re.M) #多行匹配
['1', '6']
>>> re.findall('\d$',astr) #以数字结尾
['7']
>>> re.findall('\d$',astr,re.M) #多行匹配,影响^和$
['7']
>>> re.findall('\d(.)(\d)',astr,re.S)#列表形式返回,每项为一个元组
[('3', '4'), ('a', '7')]
4、re.compile函数
compile 函数用于编译正则表达式,生成一个正则表达式( Pattern )对象。
语法如下:re.compile(pattern,flags=0)
pattern:需要匹配的正则表达式;
flags:标志位(默认为0),它可以控制正则表达式的匹配方式
常见的flags如下:
re.I 忽略匹配时的大小写
re.M 多行匹配,影响 ^ 和 $
re.S . 默认不匹配换行,使 . 匹配包括换行在内的所有字符
re.U 根据Unicode字符集解析字符。这个标志影响 \w, \W, \b, \B
示例如下:
>>> import re
>>> astr='AS12as34er567q!"3456'
>>> m1=re.compile(r'\d\d') #编译
>>> m1.search(astr).group() #匹配
'12'
>>> m1.findall(astr)
['12', '34', '56', '34', '56']
>>> m2=re.compile(r'a',re.I) #编译
>>> m2.findall(astr) #匹配
['A', 'a']
5、re.split函数
将一个字符串按照正则表达式匹配的结果进行分割,返回列表类型。
语法如下:re.split(pattern, string ,?maxsplit=0?,flags=0)
pattern:需要匹配的正则表达式;
string:在那个字符串中就行匹配 ;
maxsplit:分隔次数,maxsplit=1 分隔一次,默认为 0,不限制次数。
flags:标志位(默认为0),它可以控制正则表达式的匹配方式。
常见的flags如下:
re.I 忽略匹配时的大小写
re.M 多行匹配,影响 ^ 和 $
re.S . 默认不匹配换行,使 . 匹配包括换行在内的所有字符
re.U 根据Unicode字符集解析字符。这个标志影响 \w, \W, \b, \B
示例如下:
>>> import re
>>> astr='AS12as34er567q!"3456'
>>> astr.split('12') #通过12进行分割
['AS', 'as34er567q!"3456']
>>> re.split("\d{2}",astr) #通过两个数字进行分割
['AS', 'as', 'er', '7q!"', '', '']
>>> re.split("\d+",astr) #通过数字进行分割
['AS', 'as', 'er', 'q!"', '']
>>> m3=re.compile(r'\d+') #与上面等价,运用了compile函数
>>> m3.split(astr)
['AS', 'as', 'er', 'q!"', '']
>>> m3.split(astr,3) #指定分割几次
['AS', 'as', 'er', 'q!"3456']
6、re.sub函数
在一个字符串中替换所有匹配正则表达式的子串,返回替换后的字符串。
语法如下:re.sub(pattern, repl, string, count=0,flags=0)
pattern:需要匹配的正则表达式;
repl : 替换的字符串,也可为一个函数。
string:在那个字符串中就行匹配 ;
count : 模式匹配后替换的最大次数,默认 0 表示替换所有的匹配。
flags:标志位(默认为0),它可以控制正则表达式的匹配方式
常见的flags如下:
re.I 忽略匹配时的大小写
re.M 多行匹配,影响 ^ 和 $
re.S . 默认不匹配换行,使 . 匹配包括换行在内的所有字符
re.U 根据Unicode字符集解析字符。这个标志影响 \w, \W, \b, \B
示例如下:
>>> import re
>>> astr='AS12as34er567q!"3456'
>>> re.sub("5",'9',astr) #将5替换为9
'AS12as34er967q!"3496'
>>> m4=re.compile(r"\d+")
>>> m4.sub(' ',astr) #将数字替换为空字符串
'AS as er q!" '
>>> m4.sub(' ',astr,2) #指定替换几次
'AS as er567q!"3456'
以上就是Pthon正则表达式六种函数实例讲解,大家都懂了吗?如果对Python正则表达式还有任何疑问,可以上博学谷官网报名Python的课程,相信一定能解决大家关于学习Python的疑问。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
想学Python这些问题必须了解
在人工智能以及数据科学越来越普及的互联网环境下,Python逐渐成为炙手可热的编程语言,由于Python入门简单、就业范围广泛、薪资水平较高等诸多优势,越来越多的朋友选择通过学习Python进入互联网领域。但是入门Python前很多核心的问题你了解吗?下面小编就为大家介绍一下想学Python必须了解的问题。
4121
2019-10-30 18:51:57
Python如何做自动化测试?
众做周知,自动测试的优势是显而易见的,它可以大大节省我们的时间,提高我们的工作效率。那么Python如何做自动化测试呢?本文将用Python编写一个简单的测试用例,并指导大家写做自动化测试的代码。如果大家对这个内容感兴趣,就赶紧来一起学习吧!
4735
2020-04-30 17:13:25
怎么开始学习Python开发?0基础入门Python
怎么开始学习Python开发这个问题,在各大社群网站上常常看到想要转行IT,或者是想学习编程但不知如何开始的网友。对于新手来说,掌握Python基础是关键,了解HTML,CSS,JavaScript,Ajax,jQuery,React,SQL,服务器脚本等知识。
4040
2020-05-15 17:41:38
Python中map、filter和reduce的使用总结
在Python中我们常常会遇到需要使用map、filter和reduce三大函数的情况,大家知道分别在什么情况下使用它们吗?下面我们来逐一学习并理解Python中map、filter和reduce的使用,一起来看看吧!
4052
2020-06-26 11:11:53
Python lambda表达式学习总结
lambda表达式是⼀⾏函数,它们在其他语⾔中也被看做是没有具体名称的匿名函数。lambda表达式非常有用,它可以让代码更加简洁。如果你不想在程序中对⼀个函数使⽤两次,或许你会想⽤lambda表达式,它们和普通的函数完全⼀样。下面我们一起来看看lambda表达式的原型、代码案例、列表排序、列表并⾏排序以及lambda表达式的优劣吧!
4289
2020-06-30 12:03:41