Python 正则表达式2 语法基础

内容概述

正则表达式是由普通字符 (例如"a","b","c"等)以及特殊字符 (例如"+","-","^"等)组成的文字模式。举个例子,[a-z]这个正则表达式就代表了匹配所有的小写字母("a","b","c",...,"y","z"),相关示例代码如下:

python 复制代码
import re

# 定义正则表达式模式
pattern = r'[a-z]'
# 待匹配的字符串
text = "AaBbCcDdEeFfG"
# 使用 split() 函数进行分割
split_text = re.split(pattern, text)
print(split_text)

输出

复制代码
['A', 'B', 'C', 'D', 'E', 'F', 'G']

一般大写字母,小写字母,数字均为普通字符,其他字符中一部分是有特别含义的特殊字符(如"-"),其余部分为普通字符。特殊字符需要在后面的语法规则里面慢慢了解,记忆和掌握。

基本规则

正则表达式如果全面详细描述,其实语法内容也不少,但从实际应用来看,掌握小部分精华的规则就足够了。说实话,学习太多的规则,一来是记不住,二来是大概率用不上,所以从实用主义看没必要学习太多规则。

掌握三条核心规则就行:输入限定规则数量限定规则符号限定规则

输入限定规则

匹配输入[],匹配 [...] 中的所有字符;匹配不输入[^],匹配除了 [...] 中字符的所有字符。

举个例子,[abc][^abc],代码如下:

python 复制代码
import re

# 定义正则表达式模式
pattern = r'[abc]'
# 待匹配的字符串
text = "a1b2c3"
# 使用 split() 函数进行分割
split_text = re.split(pattern, text)
print(split_text)

pattern = r'[^abc]'
split_text = re.split(pattern, text)
print(split_text)

输出

复制代码
['', '1', '2', '3']
['a', 'b', 'c', '']

数量限定规则

如何控制匹配的字符数量呢?可以给符号后面加上有关数量的限定规则,比如n个a就表示为[a]{n},一个以上数量的a就表示为[a]+,也就是输入限定+数量限定的形式。看下面例子(注意,+对数量的匹配默认是贪婪的,来多少就吃多少,比如aaa只匹配1个结果,而不是3个分别匹配的a,要想反过来非贪婪,后面再加?即可):

python 复制代码
import re

# 待匹配的字符串
text = "I have three aaa."

pattern = r'[a]{1}'
# 使用 split() 函数进行分割
split_text = re.split(pattern, text)
print(split_text)

pattern = r'[a]{2}'
split_text = re.split(pattern, text)
print(split_text)

pattern = r'[a]+'
split_text = re.split(pattern, text)
print(split_text)

pattern = r'[a]+?'
split_text = re.split(pattern, text)
print(split_text)

输出

复制代码
['I h', 've three ', '', '', '.']
['I have three ', 'a.']
['I h', 've three ', '.']
['I h', 've three ', '', '', '.']

更多参考:

复制代码
* 零次或多次,贪婪模式
+ 一次或多次,贪婪模式
? 零次或一次
*? 零次或多次,非贪婪模式
+? 一次或多次,非贪婪模式
{n} n 次
{n,} 至少n次
{n,m} n到m次
{0,n} 最多n次

符号限定规则

首先得说明,正则表达式里面的括号()和四则运算一样能说明和改变运算的优先级,比如[a][b]{10}([a][b]){10}是不一样的,为了保证运算正确,需要用括号把[a][b]括起来才能保证我们要得到的是10个ab,不然没有括号就是a加10个b,因为数量限定会优先与前面一个输入限定进行运算。其次,有时候输入限定的括号[]也不是必须的,比如可以'(ab){10}'

除了普通字符,有些字符也有特殊含义,如下:

复制代码
A-Z 大写字母
a-z 小写字母
0-9 一位数字
. 除换行符(\n、\r)之外的任何单个字符
\s 所有空白符,包括换行
\S 非空白符,不包括换行
\w 字母、数字、下划线
\d 任意一个阿拉伯数字(0 到 9)
\n 换行符
\r 回车符
\t 制表符
| 或,比如a|b表示a或b中的一个
\ 转义特殊符,如需要输入+就转义\+

符号限定里面的字符优先级地位差不多和普通字符一样,就类似文本里面的换行符用\n去表示一样

相关推荐
AI探索者4 分钟前
LangGraph StateGraph 实战:状态机聊天机器人构建指南
python
AI探索者5 分钟前
LangGraph 入门:构建带记忆功能的天气查询 Agent
python
FishCoderh2 小时前
Python自动化办公实战:批量重命名文件,告别手动操作
python
躺平大鹅2 小时前
Python函数入门详解(定义+调用+参数)
python
曲幽3 小时前
我用FastAPI接ollama大模型,差点被asyncio整崩溃(附对话窗口实战)
python·fastapi·web·async·httpx·asyncio·ollama
两万五千个小时6 小时前
落地实现 Anthropic Multi-Agent Research System
人工智能·python·架构
哈里谢顿9 小时前
Python 高并发服务限流终极方案:从原理到生产落地(2026 实战指南)
python
用户8356290780511 天前
无需 Office:Python 批量转换 PPT 为图片
后端·python
markfeng81 天前
Python+Django+H5+MySQL项目搭建
python·django
GinoWi1 天前
Chapter 2 - Python中的变量和简单的数据类型
python