python正则表达式详细教程
时间: 2023-10-25 13:09:37 浏览: 175
Python正则表达式是一种特殊的字符序列,用于匹配和提取字符串。Python的re模块提供了Perl风格的正则表达式模式,并提供了一系列与这些模式匹配和操作字符串的函数。正则表达式具有通用性,不仅在Python中适用,也适用于其他编程语言。
下面是一些常用的正则表达式的元字符:
1. '.':匹配除换行符外的任意字符。
2. '^':匹配字符串的开头。
3. '$':匹配字符串的结尾。
4. '*':匹配前一个字符零次或多次。
5. '+':匹配前一个字符一次或多次。
6. '?':匹配前一个字符零次或一次。
7. '{m}':匹配前一个字符m次。
8. '{m,n}':匹配前一个字符至少m次,最多n次。
9. '|':匹配|前或|后的字符。
10. '\\':转义字符,用于匹配特殊字符。
常用的正则表达式函数包括:
1. re.match(pattern, string):从字符串的开头开始匹配模式。
2. re.search(pattern, string):在整个字符串中搜索匹配模式。
3. re.findall(pattern, string):返回字符串中所有匹配模式的子串列表。
4. re.sub(pattern, repl, string):将匹配模式的子串替换为指定的字符串。
5. re.split(pattern, string):根据匹配模式分割字符串。
以下是一个例子,展示了如何使用Python正则表达式进行匹配和替换:
```python
import re
# 匹配字符串开头的数字
result = re.match('\d+', '123abc')
print(result.group()) # 输出: 123
# 搜索字符串中的数字
result = re.search('\d+', 'abc123def')
print(result.group()) # 输出: 123
# 返回字符串中所有的数字
result = re.findall('\d+', 'abc123def456')
print(result) # 输出: ['123', '456']
# 将字符串中的数字替换为#号
result = re.sub('\d+', '#', 'abc123def456')
print(result) # 输出: abc#def#
# 根据逗号分割字符串
result = re.split(',', 'a,b,c,d')
print(result) # 输出: ['a', 'b', 'c', 'd']
```
阅读全文