Python——正则表达式(字符匹配-贪婪模式)

区别在于是否加?,同理在{}中也是如此

贪婪模式

{m,n}

  1. 对其之前的正则表达式进行 m 到 n 次匹配,在 m 和 n 之间取尽量多(贪婪方式)
  2. 忽略 m 则下限默认为 0,忽略 n 则上限默认为无限次(逗号不能省 略)
python 复制代码
import re

p = re.compile(r"ab{2,4}") 
print(p.search("abc"))       #None
print(p.search("abbc"))      #<re.Match object; span=(0, 3), match='abb'>
print(p.search("abbbc"))     #<re.Match object; span=(0, 4), match='abbb'>
print(p.search("abbbbc"))    #<re.Match object; span=(0, 5), match='abbbb'>
print(p.search("abbbbbc"))   #<re.Match object; span=(0, 5), match='abbbb'>

p = re.compile(r"ab{,4}")
print(p.search("ac"))        #<re.Match object; span=(0, 1), match='a'>
print(p.search("abc"))       #<re.Match object; span=(0, 2), match='ab'>

p = re.compile(r"ab{2,}")
print(p.search("abbbbc"))   #<re.Match object; span=(0, 5), match='abbbb'>
print(p.search("abbbbbc"))  #<re.Match object; span=(0, 6), match='abbbbb'>

非贪婪模式

*? +? ??

  1. " * + ? "都是贪婪的,它们对字符串进行尽可能多的匹配,有时候并不需要这种行为,可以在之后添加?,就可以以非贪婪的方式进行匹配,则尽可能少的字符将会被匹配
python 复制代码
import re

p = re.compile(r'<.*>')
print(p.search('<a> b <c>')) #<re.Match object; span=(0, 9), match='<a> b <c>'>

p = re.compile(r'<.*?>')
print(p.search('<a> b <c>')) #<re.Match object; span=(0, 3), match='<a>'>

p = re.compile(r"ab+?")
print(p.search("abbbc"))  #<re.Match object; span=(0, 2), match='ab'>

p = re.compile(r"ab??")
print(p.search("abc"))  #<re.Match object; span=(0, 1), match='a'>

{m,n}?

  1. {m,n} 的非贪婪模式
python 复制代码
import re

p = re.compile(r"ab{2,4}?")
print(p.search("abc"))    #None
print(p.search("abbc"))   #<re.Match object; span=(0, 3), match='abb'>
print(p.search("abbbc"))  #<re.Match object; span=(0, 3), match='abb'>
print(p.search("abbbbc"))  #<re.Match object; span=(0, 3), match='abb'>
print(p.search("abbbbbc"))  #<re.Match object; span=(0, 3), match='abb'>
相关推荐
ECT-OS-JiuHuaShan17 分钟前
整体论体系定理,全球开放,无法绕过
人工智能·科技·学习·算法·生活
贾斯汀玛尔斯33 分钟前
每天学一个算法--BM25(Okapi BM25)
算法
grant-ADAS1 小时前
Overlay套刻测量
算法
猿长大人1 小时前
算法 | Douglas-Peucker 拯救“腰椎间盘突出的三角形”
算法
HackTorjan1 小时前
深度解析雪花算法及其高性能优化策略
人工智能·深度学习·算法·性能优化·dreamweaver
北顾笙9801 小时前
day35-数据结构力扣
数据结构·算法·leetcode
cpp_25012 小时前
P2249 【深基13.例1】查找
数据结构·c++·算法·题解·二分·洛谷
烤麻辣烫2 小时前
算法--二分搜索
java·开发语言·学习·算法·intellij-idea
山甫aa2 小时前
二叉树算法-----从零开始的算法
数据结构·算法
睡觉就不困鸭3 小时前
第十七天 翻转字符串里的单词
数据结构·算法·哈希算法·散列表