我在偷偷学Python的第二十六天(正则表达式

编程入门 行业动态 更新时间:2024-10-15 10:15:18

<a href=https://www.elefans.com/category/jswz/34/1771440.html style=我在偷偷学Python的第二十六天(正则表达式"/>

我在偷偷学Python的第二十六天(正则表达式

findall

在字符串中找到正则表达式所匹配的所有子串,并返回一个列表,如果没有找到匹配的,则返回空列表。
注意: match 和 search 是匹配一次 findall 匹配所有。
语法格式为:

findall(string[, pos[, endpos]])

参数:

  • string : 待匹配的字符串。
  • pos : 可选参数,指定字符串的起始位置,默认为 0。
  • endpos : 可选参数,指定字符串的结束位置,默认为字符串的长度。

查找字符串中的所有数字:

import repattern = repile(r'\d+')  # 查找数字
result1 = pattern.findall('runoob 123 google 456')
result2 = pattern.findall('run88oob123google456', 0, 10)print(result1)
print(result2)test1 = pattern.findall('akopsdoasjdfoiasjfoiajs1asjfoaisfoa3')print(test1)
#['123', '456']
#['88', '12']
#['1', '3']

re.finditer

和 findall 类似,在字符串中找到正则表达式所匹配的所有子串,并把它们作为一个迭代器返回。

re.finditer(pattern, string, flags=0)
参数描述
pattern匹配的正则表达式
string要匹配的字符串。
flags标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。参见:正则表达式修饰符 - 可选标志

看:

import reit = re.finditer(r"\d+","12a32bc43jf3") 
for match in it: print (match.group() )

结果

12
32
43
3

re.split

split 方法按照能够匹配的子串将字符串分割后返回列表,它的使用形式如下:

re.split(pattern, string[, maxsplit=0, flags=0])
参数描述
pattern匹配的正则表达式
string要匹配的字符串。
maxsplit分隔次数,maxsplit=1 分隔一次,默认为 0,不限制次数。
flags标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。参见:正则表达式修饰符 - 可选标志
import re
print(re.split('\W+', 'runoob, runoob, runoob.'))
#['runoob', 'runoob', 'runoob', '']
print(re.split('(\W+)', ' runoob, runoob, runoob.'))
#['', ' ', 'runoob', ', ', 'runoob', ', ', 'runoob', '.', '']
print(re.split('\W+', ' runoob, runoob, runoob.', 1))
#['', 'runoob, runoob, runoob.']print(re.split('a*', 'hello world'))  # 对于一个找不到匹配的字符串而言,split 不会对其作出分割
#['hello world']

Time :2020/12/17
Name:Eamon

更多推荐

我在偷偷学Python的第二十六天(正则表达式

本文发布于:2024-03-07 09:37:52,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1717469.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:我在   六天   正则表达式   Python

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!