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'>
相关推荐
滋滋不吱吱5 分钟前
枚举中间位置基础篇
考研·算法·leetcode
阳光不锈@5 分钟前
算法:最长递增子序列解法记录
算法·最长递增子序列·超详细分析·java实现
遇见尚硅谷25 分钟前
C语言:20250728学习(指针)
c语言·开发语言·数据结构·c++·笔记·学习·算法
十八岁讨厌编程1 小时前
【算法训练营Day17】二叉树part7
算法
YouQian7722 小时前
(AC)Playlist
算法
算法_小学生2 小时前
决策树(Decision Tree)完整解析:原理 + 数学推导 + 剪枝 + 实战
算法·决策树·剪枝
岁忧2 小时前
(LeetCode 面试经典 150 题 ) 155. 最小栈 (栈)
java·c++·算法·leetcode·面试·go
明明如月学长4 小时前
什么你不知道 Cherry Studio 有快捷助手?
算法
Vegetable_Dragon4 小时前
数论1.01
算法
Star在努力4 小时前
15-C语言:第15天笔记
c语言·笔记·算法