【Python 正则表达式】
Python 正则表达式通过 re
模块实现模式匹配,是文本处理的核心工具。以下是系统化指南,包含语法详解和实战案例:
一、正则基础语法
1. 元字符速查表
符号 | 含义 | 示例 | 匹配结果 |
---|---|---|---|
. | 任意字符(除换行符) | r"a.c" | “abc”, “a\nc” ❌ |
^ | 行首锚定 | r"^Python" | “Python…” |
$ | 行尾锚定 | r"\.py$" | “file.py” |
\d | 数字 | r"\d{3}-\d{4}" | “010-1234” |
\D | 非数字 | r"\D+@example.com" | “user@example.com” |
\w | 单词字符(字母/数字/_) | r"\w+@\w+\.\w+" | “alice@test.com” |
\s | 空白字符 | r"hello\s+world" | “hello world” |
* | 0次或多次 | r"ab*c" | “ac”, “abc”, “abbc” |
+ | 1次或多次 | r"ab+c" | “abc”, “abbc” |
? | 0次或1次 | r"https?://" | “http://”, “https://” |
{} | 精确次数/范围 | r"\d{3,5}" | “123”, “45678” |
2. 特殊构造
# 分组与捕获
match = re.search(r"(\d{3})-(\d{4})", "010-1234")
print(match.group(1)) # "010"(第一个分组)
print(match.groups()) # ("010", "1234")# 非捕获分组
re.search(r"(?:\d{3}-){2}\d{4}", "010-1234-5678") # 不捕获中间分组# 命名分组
re.search(r"(?P<area>\d{3})-(?P<num>\d{4})", "010-1234").groupdict() # {'area': '010', 'num': '1234'}
二、核心函数详解
1. 匹配与搜索
import re# 全文匹配
re.fullmatch(r"\d{3}-\d{4}", "010-1234") # 必须完全匹配# 搜索首个匹配
re.search(r"\b\w+@\w+\.\w+\b", "Contact: alice@test.com").group() # "alice@test.com"# 搜索所有匹配
re.findall(r"\d+", "订单123,金额456元") # ['123', '456']
2. 替换操作
# 简单替换
re.sub(r"\bPython\b", "Java", "Python is great. Pythonic code.") # "Java is great. Pythonic code."# 函数替换(动态计算)
def hex_replace(match):return hex(int(match.group()))re.sub(r"\d+", hex_replace, "RGB(255,0,128)") # "RGB(0xff,0x0,0x80)"
3. 分割字符串
re.split(r"[,;\s]+", "apple, banana; cherry date") # ['apple', 'banana', 'cherry', 'date']
三、高级模式技巧
1. 贪婪与非贪婪匹配
re.findall(r"<(.*)>", "<a>text</a><b>more</b>") # 贪婪模式:['a>text</a><b>more']
re.findall(r"<(.*?)>", "<a>text</a><b>more</b>") # 非贪婪:['a', 'b']
2. 边界控制
# 单词边界
re.findall(r"\bcat\b", "The cat sat on the mat.") # ['cat']# 多行模式
re.findall(r"^Python", "Java\nPython\nC++", re.MULTILINE) # ['Python']
3. 前瞻断言
# 肯定顺序环视
re.findall(r"\b\w+(?=ing\b)", "Reading writing coding") # ['Read', 'writ', 'cod']# 否定顺序环视
re.findall(r"\b\w+(?!ing\b)", "Play played playing") # ['Play', 'played']
四、实战案例库
1. 数据验证
# 邮箱验证
EMAIL_REGEX = r"^[a-zA-Z0-9_.+-]+@[a-zA-Z0-9-]+\.[a-zA-Z0-9-.]+$"
re.fullmatch(EMAIL_REGEX, "user@example.com") # 有效# URL验证
URL_REGEX = r"https?://(?:www\.)?[^\s/$.?#].[^\s]*"
re.fullmatch(URL_REGEX, "https://www.test.com/path?query=1") # 有效
2. 文本提取
# 提取HTML标签内容
html = "<div class='content'>Hello</div><p>World</p>"
re.findall(r"<([a-z]+)>(.*?)</\1>", html, re.DOTALL) # [('div', 'Hello'), ('p', 'World')]# 解析日志时间戳
log = "2025-05-11 14:30:00 [ERROR] Connection failed"
re.search(r"\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}", log).group() # "2025-05-11 14:30:00"
3. 数据清洗
# 去除多余空格
"Hello World ".strip() # 简单方法
re.sub(r"\s+", " ", text).strip() # 正则更彻底# 隐藏敏感信息
phone = "138-1234-5678"
re.sub(r"(\d{3})\d{4}(\d{4})", r"\1****\2", phone) # "138****5678"
五、性能优化策略
1. 预编译正则对象
# 编译模式(高频使用时提升30%+性能)
email_pattern = re.compile(EMAIL_REGEX)
email_pattern.fullmatch("user@test.com") # 比直接使用re.fullmatch快
2. 避免回溯失控
# 危险模式(可能导致指数级回溯)
re.search(r"^(a+)+$", "a" * 20 + "b") # 极端情况会卡死# 安全模式(使用原子组)
re.search(r"^(?>(a+)+)b$", "aaaaab") # 快速失败
3. 匹配引擎选择
re.search()
vsre.match()
:后者强制从字符串开头匹配re.finditer()
:返回迭代器节省内存(处理大文本时)
六、调试工具推荐
-
在线测试:
- Regex101(实时可视化匹配过程)
- RegExr(内置常用正则库)
-
Python 调试:
# 打印调试信息 pattern = re.compile(r"(\d+)-(\w+)") print(pattern.pattern) # 输出正则表达式 print(pattern.flags) # 显示修饰符标志 print(pattern.groups) # 显示分组数量
七、常见陷阱避坑指南
-
特殊字符转义:
# 错误:直接使用括号 re.search(r"(123)", "test(123)test") # 无法匹配 # 正确:转义元字符 re.search(r"\(123\)", "test(123)test")
-
编码问题:
# 处理非ASCII字符时指定UNICODE标志 re.search(r"^\w+$", "中文", re.UNICODE) # Python3默认开启
-
贪婪匹配陷阱:
# 错误:贪婪匹配导致跨标签捕获 re.findall(r"<(.*)>", "<a>1</a><b>2</b>") # ['a>1</a><b>2'] # 正确:使用非贪婪模式 re.findall(r"<(.*?)>", ...) # ['a', '/a', 'b', '/b']
掌握这些技巧后,可处理90%以上的正则需求。对于复杂场景(如多语言混合文本),建议结合regex
第三方库(支持Unicode属性、模糊匹配等高级功能)。
相关文章:
【Python 正则表达式】
Python 正则表达式通过 re 模块实现模式匹配,是文本处理的核心工具。以下是系统化指南,包含语法详解和实战案例: 一、正则基础语法 1. 元字符速查表 符号含义示例匹配结果.任意字符(除换行符)r"a.c"“abc”…...

ubuntu服务器版启动卡在start job is running for wait for...to be Configured
目录 前言 一、原因分析 二、解决方法 总结 前言 当 Ubuntu 服务器启动时,系统会显示类似 “start job is running for wait for Network to be Configured” 或 “start job is running for wait for Plymouth Boot Screen Service” 等提示信息,并且…...
list简单模拟实现
成员变量迭代器(重点)ListIterator运算符重载begin、end 插入、删除inserterase头插、尾插、头删、尾删 operator->const_iterator拷贝构造operator析构函数完整代码 由于前面已经模拟实现了vector,所以这里关于一些函数实现就不会讲的过于…...

QT6 源(101)阅读与注释 QPlainTextEdit,其继承于QAbstractScrollArea,属性学习与测试
(1) (2) (3)属性学习与测试 : (4) (5) 谢谢...

Coze 实战教程 | 10 分钟打造你的AI 助手
> 文章中的 xxx 自行替换,文章被屏蔽了。 📱 想让你的xxx具备 AI 对话能力?本篇将手把手教你,如何用 Coze 平台快速构建一个能与用户自然交流、自动回复提问的 xxx助手,零代码、超高效! 📌…...
Spring Boot中Redis序列化配置详解
精心整理了最新的面试资料和简历模板,有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 引言 在使用Spring Boot集成Redis时,序列化方式的选择直接影响数据存储的效率和系统兼容性。默认的JDK序列化存在可读性差、存储空间大等问题&am…...
【spring】spring源码系列之九:spring事务管理(上)
系列文章目录 前言 在开始spring事务管理的源码分析之前,我们先自己尝试简单实现一下事务管理,实现事务的传递 一、事务的使用 有了spring之后,事务的使用变得简单,但是封装得也更深,功能也更复杂,也更…...

牛客网 NC22167: 多组数据a+b
牛客网 NC22167: 多组数据ab 题目分析 这道题目来自牛客网(题号:NC22167),要求我们计算两个整数a和b的和。乍看简单,但有以下特殊点需要注意: 输入包含多组测试数据每组输入两个整数当两个整数都为0时表示…...

K8S Ingress、IngressController 快速开始
假设有如下三个节点的 K8S 集群: k8s31master 是控制节点 k8s31node1、k8s31node2 是工作节点 容器运行时是 containerd 一、理论介绍 1)什么是 Ingress 定义:Ingress 是 Kubernetes 中的一种资源对象,它定义了外部访问集群内…...
GitHub 趋势日报 (2025年05月14日)
本日报由 TrendForge 系统生成 https://trendforge.devlive.org/ 🌐 本日报中的项目描述已自动翻译为中文 📈 今日整体趋势 Top 10 排名项目名称项目描述今日获星总星数语言1xming521/WeClone🚀从聊天记录创造数字分身的一站式解决方案&…...

快消零售AI转型:R²AIN SUITE如何破解效率困局
引言 快消零售行业正经历从“规模扩张”到“精益运营”的转型阵痛,消费者需求迭代加速、供应链复杂度攀升、人力成本持续走高,倒逼企业通过技术升级实现业务重塑[1]。RAIN SUITE以AI应用中台为核心,针对快消零售场景打造全链路提效方案&…...

电路中零极点的含义
模拟电路中的零极点设计非常重要,涉及到系统的稳定。零点是开环传输函数分子为0时对应的频率。极点就是开环传递函数分子为0时对应的频率。 零点表征电路中能量输出路径的抵消效应,当不同支路的信号大小相等、方向相反时,导致特定频率下响应…...

解读RTOS 第八篇 · 内核源码解读:以 FreeRTOS 为例
1. 引言 FreeRTOS 作为最流行的嵌入式实时操作系统之一,其内核源码简洁且功能完善。通过剖析其关键模块(任务管理、调度器、队列、内存管理和移植层),不仅能够更深入地理解 RTOS 的运行机制,还能掌握根据项目需求进行内核定制与优化的能力。本章将带你以 FreeRTOS 10.x 版…...

2025年长三角+山东省赛+ 认证杯二阶段资料助攻说明
长三角高校数模B题 完整论文代码已经在售后群 网盘链接 发布 长三角更新时间轴 5.15 23:00 B站发布 完整论文讲解视频 5.16 18:00 j降重说明 5.17 22:00 无水印版本可视化无水印代码 其余时间 写手老师 售后群在线答疑 山东省助攻C道 认证杯二阶段助攻C题 山东省认证杯…...
平滑过滤值策略
该策略是一种基于技术分析的交易策略,主要通过计算一系列指标来判断市场趋势,并根据这些指标生成交易信号。 策略概述 该策略的核心在于利用多个技术指标来分析市场动态,并据此制定交易决策。它结合了价格动量、波动性和趋势跟踪等多种因素,旨在提高交易的准确性和效率。…...
MATLAB安装全攻略:常见问题与解决方案
MATLAB安装常见问题与解决方案 一、系统兼容性验证 安装前需确认操作系统满足MATLAB版本要求: Windows 10版本1903及以上(64位)macOS Monterey 12.6及以上Ubuntu 22.04 LTS及以上 验证命令示例: # Linux系统验证 lsb_release…...
Apache HttpClient 5 用法-Java调用http服务
Apache HttpClient 5 核心用法详解 Apache HttpClient 5 是 Apache 基金会推出的新一代 HTTP 客户端库,相比 4.x 版本在性能、模块化和易用性上有显著提升。以下是其核心用法及最佳实践: 一、添加依赖 Maven 项目: <dependency><…...

鸿蒙电脑:五年铸剑开新篇,国产操作系统新引擎
出品 | 何玺 排版 | 叶媛 前不久,玺哥发布的《鸿蒙电脑,刺向垄断的利刃,将重塑全球PC市场格局》发布后,获得了读者朋友的积极反馈,不少都期望鸿蒙电脑早日发布。 如今,它真来了! 5月8日&…...
AI大模型:(二)2.5 人类对齐训练自己的模型
目录 1.人类对齐原理 1.1. 偏好学习(人类反馈,RLHF/DPO) 1.2. 奖励模型(AI的“打分老师”) 1.3. 价值观约束(如宪法AI) 2.如何人类对齐训练 2.1.对比学习(人类反馈 RLHF/DPO) 2.2.考试评分(奖励模型训练) 2.3.底线教育(安全防护) 2.4.持续优化(在线学习…...
算法图表总结:查找、排序与递归(含 Mermaid 图示)
算法图表总结:查找、排序与递归(含 Mermaid 图示) 分类标签:算法、数据结构、Mermaid、技术图表 关键词: 算法可视化、Mermaid 图表、数据结构、二分查找、快速排序、递归树 摘要: 本文通过 Mermaid 图表…...
【redis】jedis客户端的使用
Jedis是Redis官方推荐的Java客户端库,提供了对Redis数据库的全面支持,适用于单机、哨兵及集群模式。作为最老牌的Java Redis客户端,其API设计直观,与Redis命令高度对应,例如set、get等方法与原生命令一致,降…...

SQLMesh信号机制详解:如何精准控制模型评估时机
SQLMesh的信号机制为数据工程师提供了更精细的模型评估控制能力。本文深入解析信号机制的工作原理,通过简单和高级示例展示如何自定义信号,并提供实用的使用技巧和测试方法,帮助读者优化数据管道的调度效率。 一、为什么需要信号机制…...
TCP(传输控制协议)建立连接的过程
TCP(传输控制协议)建立连接的过程称为 三次握手(Three-Way Handshake)。这是为了确保通信双方能够可靠地建立连接,并同步初始序列号。以下是详细步骤: 三次握手过程(通俗比喻:打电话…...

通义千问-langchain使用构建(二)
目录 序言xinference应用构建构建过程简单概述成效 chatchat应用构建过程成效 总结 序言 在昨天的使用langchain的基础上。又尝试了构建智能问答应用。 使用langchain chatchat这个开源包,构建了一下智能问答系统。 前置项,是使用了一下xinference框架&…...

[IMX] 02.GPIO 寄存器
目录 手册对应章节 1.GPIO 复用(引脚功能选择)- IOMUXC_SW_MUX_CTL_PAD_xxx 2.GPIO 电气特性 - IOMUXC_SW_PAD_CTL_PAD_xxx 3.GPIO 数据与控制寄存器 3.1.数据 - DR 3.2.输入/输出选择 - GDIR 3.3.状态 - PSR 3.4.中断触发控制 - ICR 3.5.中断使…...

【电子通识】热敏纸的静态发色性能和动态发色性能测试方法
静态发色性能的测定 测定治具 测定静态发色曲线需要使用三个仪器,包括静态发色仪、秒表(分辨力为0.01 s)、反射光密度计(符合 GB/T23649)。 静态发色曲线使用的测试仪为静态发色仪。其结构如下图所示:包括了保湿压板、金属加热板、温度显示器、控制面板。温度能在50℃到…...
Nginx 返回 504 状态码表示 网关超时(Gateway Timeout)原因排查
Nginx 返回 504 状态码表示 网关超时(Gateway Timeout),这意味着 Nginx 作为反向代理服务器,在等待上游服务器(如后端应用服务器、数据库服务器等)响应时,超过了预设的时间限制,最终…...

AIbase推出全球MCP Server集合平台 收录超12万个MCP服务器客户端
2025年,AI领域迎来了一项重要的技术进展——MCP(Model Context Protocol,模型上下文协议)的广泛应用。全球MCP Server集合平台AIbase(https://mcp.aibase.cn/)应运而生,为AI开发者提供了一站式的MCP服务器和客户端整合…...

使用CMake中的configure_file命令自动生成项目版本信息
1 背景 随着实际项目的完善,可维护变的更加重要。在日志中保存项目的版本或是构建信息是一个非常有用的方法。 CMake提供了configure_file()命令,可以帮助开发者在构建项目时,自动生成版本或是构建信息,便于开发者在代码中直接引…...

Linux的进程管理和用户管理
gcc与g的区别 比如有两个文件:main.c mainc.cpp(分别是用C语言和C语言写的)如果要用gcc编译: gcc -o mainc main.c gcc -o mainc mainc.cpp -lstdc表明使用C标准库; 区别一: gcc默认只链接C库&#x…...