python:正则表达式

正则表达式(Regular Expressions,简称 regex)是一种强大的文本处理工具,用于匹配字符串中的字符组合。Python 提供了 re 模块来支持正则表达式的操作。以下是一些常用的正则表达式操作和示例:

导入 re 模块

首先,你需要导入 re 模块:

复制代码

python复制代码

|---|-------------|
| | import re |

基本用法

1. 匹配字符串

使用 re.match() 函数从字符串的起始位置匹配正则表达式:

复制代码

python复制代码

|---|---------------------------------------|
| | pattern = r'\d+' # 匹配一个或多个数字 |
| | match = re.match(pattern, '123abc') |
| | if match: |
| | print(match.group()) # 输出: 123 |

2. 搜索字符串

使用 re.search() 函数在字符串中搜索正则表达式(返回第一个匹配):

复制代码

python复制代码

|---|----------------------------------------|
| | pattern = r'\d+' |
| | match = re.search(pattern, 'abc123') |
| | if match: |
| | print(match.group()) # 输出: 123 |

3. 查找所有匹配项

使用 re.findall() 函数查找字符串中所有匹配正则表达式的子串:

复制代码

python复制代码

|---|-------------------------------------------------|
| | pattern = r'\d+' |
| | matches = re.findall(pattern, 'abc123def456') |
| | print(matches) # 输出: ['123', '456'] |

4. 替换字符串

使用 re.sub() 函数替换字符串中匹配正则表达式的部分:

复制代码

python复制代码

|---|------------------------------------------------------|
| | pattern = r'\d+' |
| | result = re.sub(pattern, 'number', 'abc123def456') |
| | print(result) # 输出: abcnumberdefnumber |

常用正则表达式符号

  • .:匹配除换行符以外的任意字符。
  • ^:匹配字符串的开始。
  • $:匹配字符串的结束。
  • *:匹配前面的字符零次或多次。
  • +:匹配前面的字符一次或多次。
  • ?:匹配前面的字符零次或一次。
  • {n}:匹配前面的字符恰好 n 次。
  • {n,}:匹配前面的字符至少 n 次。
  • {n,m}:匹配前面的字符至少 n 次,但不超过 m 次。
  • []:字符集,匹配括号中的任意一个字符。
  • |:逻辑或,匹配左右两边的任意一个表达式。
  • ():分组,用于提取匹配的子串。
  • \\:转义字符,用于匹配特殊字符(如 .*? 等)。

示例

匹配电子邮件地址
复制代码

python复制代码

|---|---------------------------------------------------------------|
| | pattern = r'[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}' |
| | match = re.match(pattern, 'example@example.com') |
| | if match: |
| | print("Valid email address") |
| | else: |
| | print("Invalid email address") |

匹配 URL
复制代码

python复制代码

|---|------------------------------------------------------------------------------|
| | pattern = r'https?://(?:[-\w.]|(?:%[\da-fA-F]{2}))+' |
| | match = re.search(pattern, 'Visit https://www.example.com for more info.') |
| | if match: |
| | print("Found a URL:", match.group()) |

编译正则表达式

为了提高效率,你可以使用 re.compile() 函数编译正则表达式,然后多次使用编译后的模式:

复制代码

python复制代码

|---|---------------------------------------------|
| | pattern = re.compile(r'\d+') |
| | matches = pattern.findall('abc123def456') |
| | print(matches) # 输出: ['123', '456'] |

捕获组

使用括号 () 可以捕获匹配的子串:

复制代码

python复制代码

|---|--------------------------------------------|
| | pattern = r'(\d+)-(\d+)-(\d+)' |
| | match = re.match(pattern, '2023-10-05') |
| | if match: |
| | year, month, day = match.groups() |
| | print(year, month, day) # 输出: 2023 10 05 |

命名捕获组

你可以给捕获组命名,以便更容易地访问它们:

复制代码

python复制代码

|---|-----------------------------------------------------------------------------------------|
| | pattern = r'(?P<year>\d+)-(?P<month>\d+)-(?P<day>\d+)' |
| | match = re.match(pattern, '2023-10-05') |
| | if match: |
| | print(match.group('year'), match.group('month'), match.group('day')) # 输出: 2023 10 05 |

正则表达式是一个非常强大的工具,适用于各种文本处理任务。通过掌握基本的正则表达式语法和 Python 的 re 模块,你可以高效地处理和分析字符串数据。

相关推荐
ℳ₯㎕ddzོꦿ࿐2 小时前
解决Python 在 Flask 开发模式下定时任务启动两次的问题
开发语言·python·flask
CodeClimb2 小时前
【华为OD-E卷 - 第k个排列 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
一水鉴天2 小时前
为AI聊天工具添加一个知识系统 之63 详细设计 之4:AI操作系统 之2 智能合约
开发语言·人工智能·python
Channing Lewis2 小时前
什么是 Flask 的蓝图(Blueprint)
后端·python·flask
B站计算机毕业设计超人2 小时前
计算机毕业设计hadoop+spark股票基金推荐系统 股票基金预测系统 股票基金可视化系统 股票基金数据分析 股票基金大数据 股票基金爬虫
大数据·hadoop·python·spark·课程设计·数据可视化·推荐算法
加酶洗衣粉2 小时前
MongoDB部署模式
数据库·mongodb
Suyuoa2 小时前
mongoDB常见指令
数据库·mongodb
添砖,加瓦2 小时前
MongoDB详细讲解
数据库·mongodb
Zda天天爱打卡2 小时前
【趣学SQL】第二章:高级查询技巧 2.2 子查询的高级用法——SQL世界的“俄罗斯套娃“艺术
数据库·sql
我的运维人生2 小时前
MongoDB深度解析与实践案例
数据库·mongodb·运维开发·技术共享