Python基础-----re模块(模糊匹配)

普通字符:大多数字符和字母都会和自身匹配

re.findall('alex','yuanaleSxalexwupeiqi')
    ['alex'] 
    re.findall(匹配规则,匹配字符串)
    查找出所有满足匹配规则的字符串放置于列表中

元字符:. ^ $ * + ? { } [ ] | ( ) \

  • .表示通配符,除 \n 以外均可匹配,一个 . 表示任意一个字符
ret=re.findall('a..in','helloalvin')
print(ret)#['alvin']

  • ^表示在字符串的开头匹配
ret=re.findall('^a...n','alvinhelloawwwn')
print(ret)#['alvin']
  • $ 表示在字符串的尾部匹配
ret=re.findall('a...n$','alvinhelloawwwn')
print(ret)#['awwwn']
  • *表示在贪婪匹配[0,+oo]
ret=re.findall('abc*','abcccc')#贪婪匹配[0,+oo]  
print(ret)#['abcccc']
ret=re.findall('abc*','abeerw')#贪婪匹配[0,+oo]  
print(ret)#['ab']
  • + 表示在贪婪匹配[1,+oo]
ret=re.findall('abc+','abccc')#[1,+oo]
print(ret)#['abccc']
  • 表示在贪婪匹配[0,1]可匹配0个或1个
ret=re.findall('abc?','abccc')#[0,1]
print(ret)#['abc']
ret=re.findall('abc?','abrtf')#[0,1]
print(ret)#['ab'] 
  • {}表示匹配重复情况;{0,} 等效*{1,} 等效+
ret=re.findall('abc{1,4}','abccc')  #表示匹配1-4个c均可
print(ret)#['abccc'] 贪婪匹配
  • 前面的*,+,?等都是贪婪匹配,也就是尽可能匹配,后面加?号使其变成惰性匹配,其前面的
    字符被匹配最少次数
ret=re.findall('abc*?','abcccccc')
print(ret)#['ab']
  • 元字符之字符集[]

在字符集[]* + 都失去原有意义,当做普通字符去匹配

ret=re.findall('a[bc]d','acd')     #匹配 'acd' 或 'abd'  
print(ret)#['acd']
 
ret=re.findall('[a-z]','acd')     #匹配字符串中的'a' - 'z'之间的所有字母
print(ret)#['a', 'c', 'd']
 
ret=re.findall('[.*+]','a.cd+')
print(ret)#['.', '+']
  • 在字符集[]里有功能的符号: - ^ \
ret=re.findall('[1-9]','45dha3')    #匹配字符串中的1-9之间的所有数字
print(ret)#['4', '5', '3']

ret=re.findall('[^ab]','45bdha3')  #[^]字符集中^表示非;该例表示匹配只要不是a  b即可
print(ret)#['4', '5', 'd', 'h', '3']

cal = re.findall('\([^()]*\)','12+(34*6+2-5*(3-1))')  #这里的 \ 是转义的作用
print(cal) #['(3-1)']

ret=re.findall('[\d]','45bdha3')    #\d  匹配任何十进制数;它相当于类 [0-9]。
print(ret)#['4', '5', '3']
  • 元字符之转义符 \

反斜杠后边跟元字符去除特殊功能,比如.(用于将 . 转换为普通字符用于匹配)
反斜杠后边跟普通字符实现特殊功能,比如\d

\d 匹配任何十进制数;它相当于类 [0-9]。
\D 匹配任何非数字字符;它相当于类 [^0-9]。
\s 匹配任何空白字符;它相当于类 [ \t\n\r\f\v]。
\S 匹配任何非空白字符;它相当于类 [^ \t\n\r\f\v]。
\w 匹配任何字母数字字符;它相当于类 [a-zA-Z0-9_]。(下划线也可匹配出)
\W 匹配任何非字母数字字符;它相当于类 [^a-zA-Z0-9
]
\b 匹配一个特殊字符边界,比如空格 ,&,#等

因为在python中\b本身就有特殊含义,所以需要再次转义 \b或r'\b'
ret=re.findall('I\b','I am LIST')
print(ret)#[]
ret=re.findall(r'I\b','I am LIST')
print(ret)#['I']
因为python解释器转义和re转义有别,所以需要传入多个\来转义
ret=re.findall('c\l','abc\le')
print(ret)#[]
ret=re.findall('c\\l','abc\le')
print(ret)#[]

ret=re.findall('c\\\\l','abc\le')  
print(ret)#['c\\l']
ret=re.findall(r'c\\l','abc\le')
print(ret)#['c\\l']
在控制台输入:'abc\le'实际储存的是'abc\\le'
之所以选择\b是因为\b在ASCII表中是有意义的
m = re.findall('\bblow', 'blow')
print(m)
m = re.findall(r'\bblow', 'blow')
print(m)
  • 元字符之 |

元字符|表示或的意思,其前后字符串均可以参与匹配

s = re.findall('a|b','ajkkljlbklka')
print(s)   #['a', 'b', 'a']
  • 元字符之分组()

()内的内容作为一组(整体)来匹配

m = re.findall(r'(ad)+', 'adadad')    #优先匹配()组内的内容
print(m)   #['ad']

若要匹配字符串中所有的内容,则加上?:即可取消上述优先级

m1 = re.findall(r'(?:ad)+', 'adadad')    # 【?:】可取消优先级
print(m1)   #['ad','ad','ad']

ret=re.search('(?P<id>\d{2})/(?P<name>\w{3})','23/com')
固定格式?P<id> id表示分组名称--->'23'
固定格式?P<name> name表示分组名称--->'com'
函数会在字符串内查找模式匹配,只到找到第一个匹配然后返回一个包含匹配信息的对象,该对象可以
通过调用group()方法得到匹配的字符串,如果字符串没有匹配,则返回None。
print(ret.group())#23/com
print(ret.group('id'))#23 #.group(分组名称) 可以获取分组名称对应的值

re模块下的常用方法

  • 查找所有
    re.findall('a','alvin yuan')
    返回所有满足匹配条件的结果,放在列表里

  • 查找(只到找到第一个匹配)
    re.search('a','alvin yuan').group()
    函数会在字符串内查找模式匹配,只到找到第一个匹配然后返回一个包含匹配信息的对象,该对象可以
    通过调用group()方法得到匹配的字符串,如果字符串没有匹配,则返回None。

  • 查找(仅在字符串开始处进行匹配)
    re.match('a','abc').group()
    同search,不过仅在字符串开始处进行匹配

  • 分割
    ret=re.split('[ab]','abcd')
    先按'a'分割'a'的左边无内容,则左边得到''和右边'bcd',在对''和'bcd'分别按'b'分割
    print(ret)#['', '', 'cd']

  • 替换
    ret=re.sub('\d','abc','alvin5yuan6',1)
    re.sub(参1,参2,参3,参4) 参1表示匹配规则或字符,参2表示要替换成的字符串,参3表示被匹配的字符串,参4表示指定匹配次数
    re.subn('\d','abc','alvin5yuan6')
    返回一个元组,分别为替换后字符串,和本次替换的次数

print(ret)#alvinabcyuan6
ret=re.subn('\d','abc','alvin5yuan6')
print(ret)#('alvinabcyuanabc', 2)  
  • 编译(自定义规则)可重复使用
obj=re.compile('\d{3}')            #返回一个规则对象
ret=obj.search('abc123eeee')      #规则对象可以调用.search()  .findall等方法 
print(ret.group())#123
  • 将查找的内容生成迭代器
ret=re.finditer('\d','ds3sy4784a')
print(ret)        #<callable_iterator object at 0x10195f940>
print(next(ret).group()) # '3'
print(next(ret).group()) # '4'

注 意 事 项

ret=re.findall('www.(baidu|oldboy).com','www.oldboy.com')
print(ret)#['oldboy']     

这是因为findall会优先把匹配结果组里内容返回,如果想要匹配结果,取消权限即可

ret=re.findall('www.(?:baidu|oldboy).com','www.oldboy.com')   #?: 可以去除优先级
print(ret)#['www.oldboy.com']
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容

  • 常用模块 认识模块 什么是模块 什么是模块? 常见的场景:一个模块就是一个包含了python定义和声明的文件,文...
    go以恒阅读 1,945评论 0 6
  • Python中的正则表达式(re) import rere.match #从开始位置开始匹配,如果开头没有则无re...
    BigJeffWang阅读 7,071评论 0 99
  • re模块手册 本模块提供了和Perl里的正则表达式类似的功能,不关是正则表达式本身还是被搜索的字符串,都可以...
    喜欢吃栗子阅读 4,000评论 0 13
  • 类 !/usr/bin/python -- coding: UTF-8 -- class Employee:'所有...
    SkTj阅读 951评论 0 0
  • 正则表达式、re模块、匹配单个字符、匹配多个字符、匹配开头结尾、匹配分组、re模块的高级用法、python贪婪和非...
    Cestine阅读 1,454评论 0 1