Python re.findall中正则表达式和参数re.S怎么使用
导读:本文共1858字符,通常情况下阅读需要6分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要:一、re.findall函数介绍它在re.py中有定义:deffindall(pattern,string,flags=0):"""Returnalistofallnon-overlappingmatchesinthestring.Ifoneormorecapturinggroupsarepresentinthepattern,returnalistofgrou... ...
目录
(为您整理了一些要点),点击可以直达。它在re.py中有定义:
返回string中所有与pattern匹配的全部字符串,返回形式为数组。
后面会讲解代码里的各个部分,先列出来~
str='aabbabaabbaa'
print(re.findall(r'a.b',str))#['aab','aab']
print(re.findall(r'a*b',str))#['aab','b','ab','aab','b']
print(re.findall(r'a.*b',str))#['aabbabaabb']
print(re.findall(r'a.*?b',str))#['aab','ab','aab']
print(re.findall(r'a(.*?)b',str))#['a','','a']
print(re.findall(r'a.*?b',str))#['aab','ab','aab']
print(re.findall(r'a.?b',str,re.S))#['aab','ab','aab','aa\nb']三、re.findall中正则表达式(.
?)
字符串是
1.一个 . 就 是匹配除 \n (换行符)以外的任意一个字符
2. 前面的字符出现0次或以上
3.. 贪婪,匹配从.前面为开始到后面为结束的所有内容
4..? 非贪婪,遇到开始和结束就进行截取,因此截取多次符合的结果,中间没有字符也会被截取
5.(.?) 非贪婪,与上面一样,只是与上面的相比多了一个括号,只保留括号的内容
1.字符串变为(后面多加了2个b)
2.参数无re.S,没有把最后一个换行的aab算进来
3.参数有re.S,不会对\n进行中断
Python re.findall中正则表达式和参数re.S怎么使用的详细内容,希望对您有所帮助,信息来源于网络。