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'>
相关推荐
qianpeng89723 分钟前
水声匹配场定位原理及实验
算法
董董灿是个攻城狮12 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
AI软著研究员19 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish19 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱20 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者2 天前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮2 天前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者2 天前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考2 天前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx2 天前
CART决策树基本原理
算法·机器学习