Python 正则表达式语法

Python 中的正则表达式是通过 re 模块提供的,它支持大多数正则表达式的语法。以下是一些基本的正则表达式语法元素:

  1. 字符匹配:

    • . 匹配任意单个字符,除了换行符。
    • \d 匹配任意数字,等同于 [0-9]
    • \D 匹配任意非数字字符,等同于 [^0-9]
    • \w 匹配任意字母、数字或下划线,等同于 [a-zA-Z0-9_]
    • \W 匹配任意非字母、数字或下划线字符。
  2. 字符类:

    • [abc] 匹配方括号内的任意一个字符。
    • [a-z] 匹配任意小写字母。
    • [^abc] 匹配除了方括号内的任意一个字符。
  3. 量词:

    • * 匹配前面的元素零次或多次。
    • + 匹配前面的元素一次或多次。
    • ? 匹配前面的元素零次或一次。
    • {m} 匹配确定的 m 次。
    • {m,} 至少匹配 m 次。
    • {m,n} 匹配从 m 到 n 次。
  4. 分组:

    • () 创建一个分组,可以捕获匹配的文本。
  5. 选择:

    • | 表示逻辑或,匹配两个表达式中的任意一个。
  6. 断言:

    • ^ 匹配字符串的开头。
    • $ 匹配字符串的结尾。
    • \b 匹配单词边界。
    • \B 匹配非单词边界。
  7. 特殊序列:

    • \s 匹配任何空白字符。
    • \S 匹配任何非空白字符。
    • \t 匹配制表符。
    • \n 匹配换行符。
  8. 转义:

    • \ 用于转义特殊字符或表示特殊序列。
  9. 贪婪与非贪婪:

    • 默认情况下,量词是贪婪的,尽可能多地匹配字符。在量词后面加上 ? 使其变为非贪婪,尽可能少地匹配字符。
  10. 注释:

    • (?#comment) 正则表达式中的注释,Python 3.9 及以上版本支持。

使用 re 模块的基本步骤通常包括:

  • 导入模块:import re
  • 编译正则表达式:pattern = re.compile(r'正则表达式')
  • 使用方法,如 match(), search(), findall(), sub() 等。

例如,要匹配一个邮箱地址,可以使用以下正则表达式:

python 复制代码
import re

email_pattern = r'\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b'
emails = re.findall(email_pattern, 'Please contact us at support@example.com or sales@example.net.')
print(emails)  # ['support@example.com', 'sales@example.net']

请注意,正则表达式可以非常强大,但也可能变得复杂和难以理解。始终确保测试你的正则表达式以确保它们按预期工作。

相关推荐
浪裡遊5 小时前
React Hooks全面解析:从基础到高级的实用指南
开发语言·前端·javascript·react.js·node.js·ecmascript·php
烛阴5 小时前
简单入门Python装饰器
前端·python
好开心啊没烦恼6 小时前
Python 数据分析:numpy,说人话,说说数组维度。听故事学知识点怎么这么容易?
开发语言·人工智能·python·数据挖掘·数据分析·numpy
面朝大海,春不暖,花不开6 小时前
使用 Python 实现 ETL 流程:从文本文件提取到数据处理的全面指南
python·etl·原型模式
2301_805054567 小时前
Python训练营打卡Day59(2025.7.3)
开发语言·python
万千思绪7 小时前
【PyCharm 2025.1.2配置debug】
ide·python·pycharm
微风粼粼9 小时前
程序员在线接单
java·jvm·后端·python·eclipse·tomcat·dubbo
云天徽上9 小时前
【PaddleOCR】OCR表格识别数据集介绍,包含PubTabNet、好未来表格识别、WTW中文场景表格等数据,持续更新中......
python·ocr·文字识别·表格识别·paddleocr·pp-ocrv5
你怎么知道我是队长9 小时前
python-input内置函数
开发语言·python
叹一曲当时只道是寻常10 小时前
Python实现优雅的目录结构打印工具
python