0

0

Python正则表达式使用指南_匹配搜索替换完整示例

舞夢輝影

舞夢輝影

发布时间:2025-12-31 11:31:10

|

572人浏览过

|

来源于php中文网

原创

python正则表达式核心是re模块,掌握re.search(返回首个match对象)、re.findall(返回所有匹配字符串列表)、re.finditer(返回含位置信息的match迭代器)和re.sub(支持字符串/函数替换)四大操作即可高效处理文本提取、定位与清洗任务。

python正则表达式使用指南_匹配搜索替换完整示例

Python正则表达式(regex)是处理文本的利器,核心在 re 模块。掌握匹配(re.search/re.findall)、搜索(re.finditer)、替换(re.sub)三大操作,就能应对绝大多数文本提取与清洗任务。

基础匹配:用 re.search 和 re.findall 抓取关键信息

re.search 返回第一个匹配对象(含位置和内容),适合判断是否存在或提取首个结果;re.findall 直接返回所有匹配字符串列表,更轻量、常用。

例如从日志中提取 IP 地址:

import re
log = "192.168.1.100 - - [10/Jan/2024:14:22:05] GET /index.html"
ip_pattern = r"\b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\b"
match = re.search(ip_pattern, log)
if match:
    print("找到IP:", match.group())  # 输出:192.168.1.100
<p>all_ips = re.findall(ip_pattern, log)  # 即使只有一个,也返回列表
  • 使用原始字符串 r"" 避免反斜杠转义问题
  • \b 确保匹配完整 IP,避免匹配到 192.168.1.1000 中的前段
  • 分组 () 可提取子内容,用 match.group(1) 获取第一组

精准搜索:用 re.finditer 遍历所有匹配并获取位置信息

当需要知道每个匹配在原文中的起始/结束位置,或需逐个处理带上下文的匹配项时,re.finditer 是最佳选择——它返回迭代器,每个元素是 Match 对象。

立即学习Python免费学习笔记(深入)”;

拍我AI
拍我AI

AI视频生成平台PixVerse的国内版本

下载

例如标记邮箱并记录位置:

text = "联系 admin@site.com 或 support@test.org 获取帮助"
email_pat = r"\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b"
<p>for m in re.finditer(email_pat, text):
print(f"邮箱 {m.group()} 出现在 {m.start()}-{m.end()}")</p><h1>输出:</h1><h1>邮箱 admin@site.com 出现在 3-18</h1><h1>邮箱 support@test.org 出现在 22-40</h1><p>
  • m.span() 等价于 (m.start(), m.end()),方便切片定位
  • 配合 re.I 标志可忽略大小写:re.finditer(pat, text, re.I)
  • 对大文本更省内存,比 findall 更适合流式处理

安全替换:用 re.sub 修改文本内容

re.sub 支持字符串替换和函数式替换。简单场景直接传入替换字符串;复杂逻辑(如按规则变形、计数、条件替换)则传入函数作为 repl 参数。

示例:隐藏手机号中间四位,保留前后各三位:

phone = "13812345678"
masked = re.sub(r"(\d{3})\d{4}(\d{4})", r"\1****\2", phone)
print(masked)  # 输出:138****5678
<h1>或用函数实现动态逻辑</h1><p>def mask_by_len(match):
full = match.group()
if len(full) == 11 and full.isdigit():
return full[:3] + "****" + full[-4:]
return full</p><p>re.sub(r"\d{11}", mask_by_len, "回拨13812345678试试")  # → 回拨138****5678试试
  • 替换字符串中用 \1\2 引用捕获组,注意是反斜杠+数字,不是 $1
  • 函数参数必须接收一个 Match 对象,返回字符串
  • count=1 参数可限制只替换首次匹配

实用技巧与避坑提醒

正则写得再准,运行出错或结果不符常因细节疏忽。以下几点高频影响效果:

  • 默认不匹配换行符:. 不会匹配 \n,需加 re.DOTALL 标志
  • 贪婪 vs 非贪婪:.* 会尽可能多匹配,改成 .*? 实现最小匹配
  • 中文匹配要小心编码:确保字符串是 str 类型(非 bytes),模式中可直接写中文或用 [\u4e00-\u9fff]
  • 编译正则提升性能:pattern = re.compile(r"\d+"),后续多次调用 pattern.search() 更快
  • 特殊字符如 .+*?[^$ 在模式中需用 \ 转义才能表示字面意义

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

正则表达式不包含
正则表达式不包含

正则表达式,又称规则表达式,,是一种文本模式,包括普通字符和特殊字符,是计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,通常被用来检索、替换那些符合某个模式的文本。php中文网给大家带来了有关正则表达式的相关教程以及文章,希望对大家能有所帮助。

258

2023.07.05

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

766

2023.07.05

java正则表达式匹配字符串
java正则表达式匹配字符串

在Java中,我们可以使用正则表达式来匹配字符串。本专题为大家带来java正则表达式匹配字符串的相关内容,帮助大家解决问题。

219

2023.08.11

正则表达式空格
正则表达式空格

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。本专题为大家提供正则表达式相关的文章、下载、课程内容,供大家免费下载体验。

356

2023.08.31

Python爬虫获取数据的方法
Python爬虫获取数据的方法

Python爬虫可以通过请求库发送HTTP请求、解析库解析HTML、正则表达式提取数据,或使用数据抓取框架来获取数据。更多关于Python爬虫相关知识。详情阅读本专题下面的文章。php中文网欢迎大家前来学习。

293

2023.11.13

正则表达式空格如何表示
正则表达式空格如何表示

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。想了解更多正则表达式空格怎么表示的内容,可以访问下面的文章。

244

2023.11.17

正则表达式中如何匹配数字
正则表达式中如何匹配数字

正则表达式中可以通过匹配单个数字、匹配多个数字、匹配固定长度的数字、匹配整数和小数、匹配负数和匹配科学计数法表示的数字的方法匹配数字。更多关于正则表达式的相关知识详情请看本专题下面的文章。php中文网欢迎大家前来学习。

547

2023.12.06

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号