当前位置: 首页 > news >正文

Python 字符串正则表达式详解

Python 字符串正则表达式详解


一、正则表达式核心语法

元字符含义正确示例与说明常见错误修正
.匹配任意字符(换行符除外)a.b → 匹配"acb"、“a1b”不匹配换行符(需用re.S模式)
^匹配字符串开头^Hello → 匹配以"Hello"开头的字符串需与re.M模式配合匹配行首
$匹配字符串结尾world$ → 匹配以"world"结尾的字符串需与re.M模式配合匹配行尾
*匹配前导模式0次或多次ab* → 匹配"a"、“ab”、“abb”易与+混淆(+需至少1次)
+匹配前导模式1次或多次ab+ → 匹配"ab"、“abb”,不匹配"a"需注意最小匹配次数限制
?匹配前导模式0次或1次ab? → 匹配"a"或"ab"常用于可选字符匹配(如s?he
\d匹配数字(等价于[0-9]\d{3} → 匹配"123"、"456"等三位数注意转义符需使用原始字符串r""
\w匹配字母、数字、下划线\w+ → 匹配"user123"、“var_1”不匹配特殊符号,如emoji 😒😒😒
\s匹配空白字符(空格、制表符等)a\s+b → 匹配"a b"、“a\tb”不匹配换行符(需用\n
[]匹配括号内任意一个字符[abc] → 匹配"a"、“b”、“c”范围表示法如[a-z0-9]
()分组捕获,可引用分组内容(ab)+ → 匹配"ab"、“abab”\1引用分组(如替换操作)

1. 基础元字符

  • .:匹配除换行符外的任意字符
    re.search(r"a.c", "abc")  # 匹配 "abc"
    
  • ^ / $:分别匹配字符串的开始结束
    re.match(r"^user", "user123")  # 验证用户名以"user"开头
    
  • * / + / ?:量词,分别表示0次或多次1次或多次0次或1次匹配
       # 匹配所有结果
      print(re.findall(r"ab*c", "ac"))
      print(re.findall(r"ab*c", "abc" ))
      print(re.findall(r"ab*c", "abbc") )
    

2. 预定义字符集

  • \d:匹配数字(等价于 [0-9]
  • \w:匹配字母、数字、下划线(等价于 [a-zA-Z0-9_]
  • \s:匹配空白字符(如空格、制表符)
  • [ ]:自定义字符集合(如 [a-z] 匹配小写字母)
    re.findall(r"\d{3}", "ID:123")  # 提取连续3位数字 → ['123']
    

3. 分组与引用

  • ( ):捕获分组,可通过 group() 提取
    match = re.search(r"(\d{4})-(\d{2})", "2025-03")
    print(match.group(1))  # 输出年份 "2025"
    
  • \1\3:引用第一和第三个分组(用于替换操作)
	re.sub(r"(\d{3})(\d{4})(\d{4})", r"\1****\3", "13812345678")  # → "138****5678"

二、re 模块核心方法

1. 常用函数

方法用途示例代码片段
re.search()扫描整个字符串,返回第一个匹配re.search(r"\d+", "价格:99元") → 匹配 “99”
re.match()仅从字符串开头匹配re.match(r"^http", url) 验证URL协议头
re.findall()返回所有匹配的列表re.findall(r"\b\w+@\w+\.com\b", text) 提取邮箱
re.sub()替换匹配内容re.sub(r"\s+", " ", text) 合并多余空格

2. 匹配模式修饰符

  • re.I:忽略大小写
    re.findall(r"python", "Python is great", flags=re.I)  # 匹配 ["Python"]
    
  • re.M:多行模式(使 ^$ 匹配每行的开始/结束)
  • re.S:使 . 匹配包括换行符在内的所有字符

三、高级应用技巧

1. 贪婪与非贪婪模式

  • 贪婪(默认):尽可能匹配更长内容
    re.search(r"<div>.*</div>", "<div>A</div><div>B</div>")  # 匹配整个字符串
    
  • 非贪婪(加 ?):匹配最短内容
    re.search(r"<div>.*?</div>", "<div>A</div><div>B</div>")  # 仅匹配第一个<div>
    

2. 转义处理

  • 使用原始字符串r"")避免反斜杠冲突
    re.search(r"\\", "路径: C:\\Users")  # 匹配单个反斜杠
    

3. 实用正则模板

  • 邮箱验证r"^\w+([.-]?\w+)*@\w+([.-]?\w+)*(\.\w{2,3})+$"
  • 手机号提取r"1[3-9]\d{9}"
  • URL提取r"https?://[\w.-]+\.[a-z]{2,}"

四、常见问题与优化

  1. 中文字符匹配
    使用 Unicode 范围:[\u4e00-\u9fa5]

    re.findall(r"[\u4e00-\u9fa5]+", "Hello 世界")  # 提取中文 → ["世界"]
    
  2. 性能优化

    • 预编译正则表达式:pattern = re.compile(r"\d+")
    • 避免过度使用.*,尽量明确匹配范围

完整正则语法参考:Python 官方文档 | 在线测试工具:regex101.com

相关文章:

  • 第 1 章 | 开篇词:Dapp安全 区块链安全 Web3安全 区块链合约一旦部署,安全就是生死线
  • AI加速,制造企业如何用数据驱动质量管理数字化变革?
  • 18 C语言标准头文件
  • Linux 挂载磁盘操作指南
  • React-Router路由跳转、传参、抽象封装以及嵌套路由
  • MySQL - 索引【index】
  • Axure项目实战:智慧城市APP(一)首页(动态面板、拖动效果)
  • 聚水潭商品信息集成MySQL的高效解决方案
  • React 中React.memo的作用,如何利用它进行组件性能优化?
  • Harbor镜像仓库迁移与高可用集群搭建HTTPS实现实战指南
  • 【Python】pillow库学习笔记1-Image类
  • SpringCould微服务架构之Docker(2)
  • 图解预训练模型 ELMo 和 BERT
  • 数据结构十四、哈希表
  • 监控告警+webhook一键部署
  • Json在扩展属性xdata中的应用实例——cad 二次开发c#
  • python每日十题(9)
  • 【FAQ】HarmonyOS SDK 闭源开放能力 —Push Kit(11)
  • AI小白的第七天:必要的数学知识(概率)
  • Netty实现SCPI协议通信
  • asp新闻发布网站模板/seo关键词平台
  • 长沙房产网最新楼盘/seo外链购买
  • ip查询网站备案查询系统/做一个网站
  • wordpress日志在哪个文件/关键词首页排名优化公司推荐
  • 数字展厅网站建设/沈阳seo排名优化推广
  • 阿里巴巴怎么做网站/sem优化和seo的区别