随笔 - 77  文章 - 0  评论 - 0  阅读 - 21309 

# ### 正则表达式 => 多个字符匹配

# (1) 量词基本语法
import re
'''1) ? 匹配0个或者1个a '''
print(re.findall('a?b','abbzab abb aab')) # ab b ab ab b ab

'''2) + 匹配1个或者多个a '''
print(re.findall('a+b','b ab aaaaaab abb')) # ab aaaaaab ab

'''3) * 匹配0个或者多个a '''
print(re.findall('a*b','b ab aaaaaab abbbbbbb')) # b ab aaaaaab ab b b b b b b

'''4) {m,n} 匹配m个至n个a '''
"""1<= x <=3"""
print(re.findall('a{1,3}b','aaab ab aab abbb aaz aabb')) # aaab ab aab ab aab
# {m,} 至少m次
print(re.findall('a{2,}b','aaab ab aab abbb aaz aabb')) # aaab aab aab
# {m} 必须m次
print(re.findall('a{2}b','aaab ab aab abbb aaz aabb')) #aab aab aab

# (2)贪婪模式与非贪婪模式
"""
贪婪模式 : 默认向更多次匹配
非贪婪模式: 默认向更少次匹配

贪婪模式在底层使用的是回溯算法:
回溯算法:默认从左向右进行匹配,一直到最后,直到最后再也匹配不到了,回头,找最后一个能够匹配到的数据

非贪婪模式: 在量词的后面加?,这个语法就是非贪婪,默认向更少次匹配
.?? .+? .*? .{1,25}?
"""
# 贪婪模式
strvar = "刘能和刘德华和刘铁锤子777子888"
lst = re.findall("刘.",strvar) #刘能 刘德 刘铁
print(lst)

lst = re.findall("刘.?",strvar) #刘能 刘德 刘铁
print(lst)

lst = re.findall("刘.+",strvar) #['刘能和刘德华和刘铁锤子777子888']
print(lst)

lst = re.findall("刘.*",strvar) #['刘能和刘德华和刘铁锤子777子888']
print(lst)

lst = re.findall("刘.{1,25}",strvar) #['刘能和刘德华和刘铁锤子777子888']
print(lst)

lst = re.findall("刘.{1,25}子",strvar) # ['刘能和刘德华和刘铁锤子777子']
print(lst)

# 非贪婪模式
strvar = "刘能和刘德华和刘铁锤子777子888"
lst = re.findall("刘.??",strvar) #['刘', '刘', '刘']
print(lst)

lst = re.findall("刘.+?",strvar) #刘能 刘德 刘铁
print(lst)

lst = re.findall("刘.*?",strvar) #['刘', '刘', '刘']
print(lst)

lst = re.findall("刘.{1,25}?",strvar) #刘能 刘德 刘铁
print(lst)

lst = re.findall("刘.{1,25}?子",strvar) # ['刘能和刘德华和刘铁锤子']
print(lst)


# (3) 边界符
"""
转义字符 :\b backspace 退格
边界符也用的是\b,要注意转义
例如:word 卡住边界
(1) 卡住左边界 \bw
(2) 卡住右边界 d\b
"""
strvar = "pwd word szf"
lst = re.findall(r"\bw.*",strvar)
lst = re.findall(r"\bw.*?",strvar)
lst = re.findall(r"\bw.*? ",strvar)
lst = re.findall(r"\bw\S*",strvar)

print(lst)
lst = re.findall(r"d\b",strvar)
lst = re.findall(r".*d\b",strvar)
lst = re.findall(r".*?d\b",strvar) # ['pwd', ' word']
print(lst)


# (4) ^ $
"""
^ 以...开头
$ 以...结尾
如果正则表达式里面出现了^ $ ,代表把这个字符串看成一个整体,再去匹配
"""

strvar = "大哥大嫂大爷"
print(re.findall('大.',strvar)) # 大哥 大嫂 大爷
print(re.findall('^大.',strvar)) # 大哥
print(re.findall('大.$',strvar)) # ['大爷']
print(re.findall('^大.$',strvar))# []
print(re.findall('^大.*?$',strvar)) # 大哥大嫂大爷
print(re.findall('^大.*?大$',strvar)) # []
print(re.findall('^大.*?爷$',strvar)) # ['大哥大嫂大爷']

print(re.findall('^g.*? ' , 'giveme 1gfive gay')) #giveme
print(re.findall('five$' , 'aassfive')) # five
print(re.findall('^giveme$' , 'giveme')) # giveme
print(re.findall('^giveme$' , 'giveme giveme')) # []
print(re.findall('giveme' , 'giveme giveme')) #[giveme giveme]
print(re.findall("^g.*e",'giveme 1gfive gay')) #giveme 1gfive

 

posted on   rider_yang  阅读(1852)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示