正则表达式中常见的贪婪词

1. *

  • 含义:匹配前面的元素零次或者多次。
  • 示例 :对于正则表达式 a*,在字符串 "aaaa" 中,它会匹配整个 "aaaa",因为它会尽可能多地匹配 a 字符。
  • 代码示例(Python)
python 复制代码
import re
text = "aaaa"
pattern = re.compile(r'a*')
result = pattern.search(text)
print(result.group())  # 输出: aaaa

2. +

  • 含义:匹配前面的元素一次或者多次。
  • 示例 :正则表达式 a+ 在字符串 "aaaa" 中,同样会匹配整个 "aaaa",不过它至少要匹配一次 a 字符。
  • 代码示例(Python)
python 复制代码
import re
text = "aaaa"
pattern = re.compile(r'a+')
result = pattern.search(text)
print(result.group())  # 输出: aaaa

3. ?

  • 含义:匹配前面的元素零次或者一次。
  • 示例 :正则表达式 colou?r 可以匹配 "color""colour"u? 表示 u 这个字符可以出现零次或者一次。
  • 代码示例(Python)
python 复制代码
import re
text1 = "color"
text2 = "colour"
pattern = re.compile(r'colou?r')
result1 = pattern.search(text1)
result2 = pattern.search(text2)
print(result1.group())  # 输出: color
print(result2.group())  # 输出: colour

4. {n,}

  • 含义 :匹配前面的元素至少 n 次。
  • 示例 :正则表达式 a{2,} 在字符串 "aaaa" 中,会匹配整个 "aaaa",因为它要求 a 至少出现 2 次。
  • 代码示例(Python)
python 复制代码
import re
text = "aaaa"
pattern = re.compile(r'a{2,}')
result = pattern.search(text)
print(result.group())  # 输出: aaaa

5. {n,m}

  • 含义 :匹配前面的元素至少 n 次,但不超过 m 次。
  • 示例 :正则表达式 a{2,3} 在字符串 "aaaa" 中,会匹配前三个 a,即 "aaa",因为它尽量在 2 到 3 次的范围内进行最大匹配。
  • 代码示例(Python)
python 复制代码
import re
text = "aaaa"
pattern = re.compile(r'a{2,3}')
result = pattern.search(text)
print(result.group())  # 输出: aaa

贪婪字符会尽可能多地去匹配符合条件的字符,直到无法再匹配为止,因此会导致回溯问题,因此在实际应用中,应该避免使用贪婪字符。

如果想让贪婪字符变为非贪婪模式,只需在其后加上 ? 即可,如:*?+???{n,}?{n,m}?,

此模式将会尽可能少的去匹配字符,但是可能无法达到预期结果,大家酌情选择。

相关推荐
gentle_ice1 分钟前
leetcode——矩阵置零(java)
java·算法·leetcode·矩阵
HaoHao_01017 分钟前
AWS Snowball
服务器·云计算·aws·云服务器
whisperrr.1 小时前
【JavaWeb06】Tomcat基础入门:架构理解与基本配置指南
java·架构·tomcat
dot to one1 小时前
Linux 入门 常用指令 详细版
linux·服务器·centos
火烧屁屁啦2 小时前
【JavaEE进阶】应用分层
java·前端·java-ee
m0_748257462 小时前
鸿蒙NEXT(五):鸿蒙版React Native架构浅析
java
狄加山6752 小时前
Linux 基础1
linux·运维·服务器
我没想到原来他们都是一堆坏人2 小时前
2023年版本IDEA复制项目并修改端口号和运行内存
java·ide·intellij-idea
Zfox_3 小时前
HTTP cookie 与 session
linux·服务器·网络·c++·网络协议·http
Suwg2094 小时前
【由浅入深认识Maven】第1部分 maven简介与核心概念
java·maven