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

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修图工具,支持手脚修复、商品重绘、AI扩图、AI换色

下载

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

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"

for m in re.finditer(email_pat, text): print(f"邮箱 {m.group()} 出现在 {m.start()}-{m.end()}")

输出:

邮箱 admin@site.com 出现在 3-18

邮箱 support@test.org 出现在 22-40

  • 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

或用函数实现动态逻辑

def mask_by_len(match): full = match.group() if len(full) == 11 and full.isdigit(): return full[:3] + "****" + full[-4:] return full

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() 更快
  • 特殊字符如 .+*?[^$ 在模式中需用 \ 转义才能表示字面意义

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

715

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

625

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

739

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1235

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

575

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

698

2023.08.11

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

0

2025.12.31

热门下载

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

精品课程

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

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 2.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.0万人学习

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

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