Python正则表达式常用特殊字符及其含义示例详解
更新时间:2026年02月26日 11:28:00 作者:遇到BUG就睡觉
Python正则表达式是一种强大的文本匹配工具,常用于处理字符串、解析HTML、爬虫等领域,这篇文章主要介绍了Python正则表达式常用特殊字符及其含义的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
以下是 Python 正则表达式常用特殊字符及其含义 的全面整理,涵盖了常见和重要的正则符号,以及它们的示例,适合用来写博客或学习使用:
Python 正则表达式常用特殊字符及其含义
1. . (点号)
- 含义:匹配除换行符
\n以外的任意单个字符。 - 示例:
import re pattern = r"a.b" print(re.match(pattern, "acb")) # 匹配成功,"a.b" 中间任意字符 print(re.match(pattern, "a\nb")) # 不匹配,中间是换行符
2. ^ (脱字符)
- 含义:匹配字符串的开头。
- 示例:
pattern = r"^Hello" print(re.match(pattern, "Hello world")) # 匹配成功 print(re.match(pattern, "world Hello")) # 不匹配
3. $ (美元符)
- 含义:匹配字符串的结尾。
- 示例:
pattern = r"world$" print(re.search(pattern, "Hello world")) # 匹配成功 print(re.search(pattern, "Hello world!")) # 不匹配
4. * (星号)
- 含义:匹配前面的字符零次或多次。
- 示例:
pattern = r"ab*" print(re.match(pattern, "a")) # 匹配成功,b 出现零次 print(re.match(pattern, "abbb")) # 匹配成功,b 出现多次
5. + (加号)
- 含义:匹配前面的字符一次或多次。
- 示例:
pattern = r"ab+" print(re.match(pattern, "ab")) # 匹配成功,b 出现一次 print(re.match(pattern, "a")) # 不匹配,至少需要一个 b
6. ? (问号)
- 含义:匹配前面的字符零次或一次。
- 示例:
pattern = r"ab?" print(re.match(pattern, "a")) # 匹配成功,b 出现零次 print(re.match(pattern, "ab")) # 匹配成功,b 出现一次 print(re.match(pattern, "abb")) # 不匹配,b 出现两次
7. {n}, {n,}, {n,m} (量词限定符)
- 含义:
{n}:匹配前一个字符恰好 n 次。{n,}:匹配至少 n 次。{n,m}:匹配至少 n 次,至多 m 次。
- 示例:
pattern = r"ab{2,4}" print(re.match(pattern, "abb")) # 匹配成功,b 出现 2 次 print(re.match(pattern, "abbbb")) # 不匹配,b 超过 4 次
8. [...] (字符类)
- 含义:匹配方括号内的任意字符。
[a-z]:表示范围,匹配从a到z的任意字符。[^...]:取反,匹配不在方括号内的任意字符。
- 示例:
pattern = r"[aeiou]" print(re.match(pattern, "apple")) # 匹配成功,匹配元音字母 'a' pattern2 = r"[^aeiou]" print(re.match(pattern2, "hello")) # 匹配 'h',不是元音字母
9. - (连字符/减号)
- 含义:在字符类中,表示范围。
[a-z]:从a到z。[A-Z]:从A到Z。[-]:如果-出现在开头或结尾,匹配减号本身。
- 示例:
pattern = r"[a-z0-9]" print(re.match(pattern, "5")) # 匹配成功,数字在范围内 print(re.match(pattern, "g")) # 匹配成功,字母在范围内
10. | (管道符)
- 含义:表示逻辑 "或",匹配左边或右边的规则。
- 示例:
pattern = r"cat|dog" print(re.match(pattern, "cat")) # 匹配成功 print(re.match(pattern, "dog")) # 匹配成功
11. () (分组和捕获)
- 含义:将多个字符作为一个整体进行匹配,并捕获组内容。
- 示例:
pattern = r"(ab)+" print(re.match(pattern, "abab")) # 匹配成功
12. \ (反斜杠)
- 含义:用于转义特殊字符,或表示特殊的匹配序列。
\d:匹配数字[0-9]。\s:匹配空白字符(如空格、制表符)。\w:匹配字母、数字和下划线[a-zA-Z0-9_]。\D、\S、\W:与上述序列的反义。
- 示例:
pattern = r"\d+" print(re.match(pattern, "12345")) # 匹配成功 print(re.match(pattern, "abc")) # 不匹配
13. \b 和 \B (单词边界)
\b:匹配单词边界。\B:匹配非单词边界。- 示例:
pattern = r"\bcat\b" print(re.search(pattern, "a cat sat")) # 匹配成功,完整的单词 'cat' pattern2 = r"cat\B" print(re.search(pattern2, "concatenate")) # 匹配成功,'cat' 后非边界
14. 零宽断言 (Lookaround)
(?=...):正向肯定预查。(?!...):正向否定预查。(?<=...):后向肯定预查。(?<!...):后向否定预查。- 示例:
pattern = r"(?<=\$)\d+" print(re.search(pattern, "价格是$100")) # 匹配 '100',不包括 '$'
15. 命名组和引用
(?P<name>...):定义命名分组。(?P=name):引用命名分组。- 示例:
pattern = r"(?P<number>\d+)\s+(?P=number)" print(re.match(pattern, "123 123")) # 匹配两个相同的数字
以上内容全面涵盖了 Python 正则表达式中的常用特殊字符及其含义,并结合示例展示了每个符号的实际用法,适合用于博客或深入学习。
总结
到此这篇关于Python正则表达式常用特殊字符及其含义示例详解的文章就介绍到这了,更多相关Python正则特殊字符及含义内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
python生成可执行exe控制Microsip自动填写号码并拨打功能
这篇文章主要介绍了python生成可执行exe控制Microsip自动填写号码并拨打,在这需要注意一个问题,必须是已经运行Microsip.exe文件,具体实现代码跟随小编一起看看吧2021-06-06
Python实战之手把手教你写一个带界面的照片按日期归档与清理工具
这篇文章主要为大家详细介绍了如何将利用 Python 和 wxPython 图形界面库,编写一个自动化的工具,不仅能按拍摄日期自动归档媒体文件,还能在校验成功后安全地将源文件移入回收站,感兴趣的小伙伴可以了解下2025-11-11
Nginx+Uwsgi+Django 项目部署到服务器的思路详解
这篇文章主要介绍了Nginx+Uwsgi+Django 项目部署到服务器的思路,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-05-05


最新评论