正则表达式中的贪婪模式和非贪婪模式

正则表达式中的贪婪模式和非贪婪模式

    • [一. 贪婪模式(Greedy Mode)](#一. 贪婪模式(Greedy Mode))
    • [二. 非贪婪模式(Non-Greedy Mode)](#二. 非贪婪模式(Non-Greedy Mode))
    • 三.应用场景区别

这是我在这个网站整理的笔记,有错误的地方请指出,关注我,接下来还会持续更新。

作者:神的孩子都在歌唱

一. 贪婪模式(Greedy Mode)

定义 : 贪婪模式是正则表达式的默认匹配模式。在贪婪模式下,量词会尝试匹配尽可能多的字符。贪婪量词包括 *+?{n,m} 等。

示例:

假设我们有以下字符串:

text 复制代码
<a>First</a><a>Second</a>

使用贪婪模式的正则表达式 <a>.*</a> 来匹配 <a></a> 之间的内容:

python 复制代码
import re

text = "<a>First</a><a>Second</a>"
pattern = re.compile(r"<a>.*</a>")
matches = pattern.findall(text)
print(matches)

输出:

plaintext 复制代码
['<a>First</a><a>Second</a>']

正则表达式 <a>.*</a> 匹配了整个字符串,因为 .* 尽可能多地匹配字符,直到最后一个 </a>

二. 非贪婪模式(Non-Greedy Mode)

定义: 非贪婪模式也称为懒惰模式(Lazy Mode)。在非贪婪模式下,量词会尝试匹配尽可能少的字符。非贪婪量词通过在贪婪量词后面加上一个问号 ? 来表示,例如 *?+???{n,m}? 等。

示例

使用非贪婪模式的正则表达式 <a>.*?</a> 来匹配 <a></a> 之间的内容:

python 复制代码
import re

text = "<a>First</a><a>Second</a>"
pattern = re.compile(r"<a>.*?</a>")
matches = pattern.findall(text)
print(matches)

输出:

plaintext 复制代码
['<a>First</a>', '<a>Second</a>']

正则表达式 <a>.*?</a> 分别匹配了两个 <a> 标签和它们之间的内容,因为 .*? 尽可能少地匹配字符,直到遇到第一个 </a>

三.应用场景区别

  • 贪婪模式:适用于需要匹配尽可能多内容的情况。
  • 非贪婪模式:适用于需要匹配尽可能少内容的情况,避免过度匹配。

作者:神的孩子都在歌唱

本人博客:https://blog.csdn.net/weixin_46654114

转载说明:务必注明来源,附带本人博客连接。

相关推荐
!chen15 小时前
解决 Oracle 监听外网 IP
数据库·tcp/ip·oracle
LBuffer16 小时前
破解入门学习笔记题四十六
数据库·笔记·学习
chase。16 小时前
关于 nvidia-smi: no devices were found 解决方案
服务器·数据库·postgresql
几何心凉16 小时前
openGauss:多核时代企业级数据库的性能与高可用新标杆
前端·数据库·数据库开发
q***040517 小时前
在 Ubuntu 上安装 MySQL 的详细指南
mysql·ubuntu·adb
瑞思蕊萌17 小时前
redis实战篇--商品缓存模块
数据库·redis·缓存
AiXed18 小时前
PC微信协议之AES-192-GCM算法
前端·数据库·python
武子康20 小时前
Java-171 Neo4j 备份与恢复 + 预热与执行计划实战
java·开发语言·数据库·性能优化·系统架构·nosql·neo4j
无敌最俊朗@20 小时前
02-SQLite 为了防止多人同时乱写,把整个数据库文件“当一本账本加锁”
jvm·数据库·oracle
小坏讲微服务20 小时前
MaxWell中基本使用原理 完整使用 (第一章)
大数据·数据库·hadoop·sqoop·1024程序员节·maxwell