正则表达式(RegEx)是一系列字符,形成了一个搜索模式。RegEx 可用于检查字符串是否包含指定的搜索模式。

RegEx 模块

Python 中有一个内置的包叫做 re,它可以用于处理正则表达式。导入 re 模块:

import re

Python 中的 RegEx,一旦导入了 re 模块,您就可以开始使用正则表达式了。

示例:搜索字符串以查看它是否以 "The" 开头并以 "Spain" 结尾:

import re

txt = "The rain in Spain"
x = re.search("^The.*Spain$", txt)

RegEx 函数

re 模块提供了一组函数,允许我们在字符串中搜索匹配项:

函数  描述

findall  返回包含所有匹配项的列表

search  如果字符串中的任何位置存在匹配项,则返回一个 Match 对象

split  返回一个列表,其中字符串已在每个匹配项处拆分

sub  用字符串替换一个或多个匹配项

元字符

元字符是具有特殊含义的字符:

字符  描述  示例

[]  一组字符  "[a-m]"  

\  表示特殊序列(也可以用于转义特殊字符)  "\d"  

.  任何字符(除换行符之外的任何字符)  "he..o"  

^  以...开始  "^hello"  

$  以...结束  "planet$"  

- 零次或多次出现  "he.*o"
- 一次或多次出现 "he.+o" ? 零次或一次出现 "he.?o" {} 指定次数的出现次数 "he.{2}o" | 要么是...,要么是... "falls|stays" () 捕获和分组

特殊序列

特殊序列是一个 \ 后面跟着下面列表中的一个字符,具有特殊含义:

字符  描述  示例

\A  如果指定的字符位于字符串的开头,则返回一个匹配项  "\AThe"  

\b  返回指定字符在单词的开头或结尾的匹配项

(开头的 "r" 确保字符串被视为“原始字符串”)  r"\bain"

r"ain\b"  

\B  返回指定字符存在但不在单词的开头(或结尾)的匹配项

(开头的 "r" 确保字符串被视为“原始字符串”)  r"\Bain"

r"ain\B"  

\d  返回字符串包含数字(0-9)的匹配项  "\d"  

\D  返回字符串不包含数字的匹配项  "\D"  

\s  返回字符串包含空白字符的匹配项  "\s"  

\S  返回字符串不包含空白字符的匹配项  "\S"  

\w  返回字符串包含任何单词字符的匹配项(从 a 到 Z,从 0 到 9,以及下划线 _ 字符)  "\w"  

\W  返回字符串不包含任何单词字符的匹配项  "\W"  

\Z  如果指定的字符位于字符串的末尾,则返回一个匹配项  "Spain\Z"

集合

集合是一个放在一对方括号 [] 中的一组字符,具有特殊含义:

集合  描述

[arn]  返回一个匹配项,其中存在指定的字符(a、r 或 n)

[a-n]  返回任何小写字符的匹配项,字母顺序在 a 和 n 之间

[^arn]  返回除 a、r 和 n 之外的任何字符的匹配项

[0123]  返回字符串中存在任何指定的数字(0、1、2 或 3)的匹配项

[0-9]  返回字符串中存在任何数字(0 到 9)的匹配项

[0-5][0-9]  返回字符串中存在任何两位数的匹配项,介于 00 和 59 之间

[a-zA-Z]  返回任何字母字符的匹配项,字母顺序在 a 到 z 之间,不区分大小写

[+]  在集合中,+、*、.、|、()、$、{} 没有特殊含义,因此 [+] 意味着:返回字符串中的任何 + 字符的匹配项

findall() 函数

findall() 函数返回一个包含所有匹配项的列表。

示例:打印所有匹配项的列表:

import re

txt = "The rain in Spain"
x = re.findall("ai", txt)
print(x)

该列表按照找到的顺序包含匹配项。如果没有找到匹配项,则返回一个空列表:

示例:如果未找到匹配项,则返回一个空列表:

import re

txt = "The rain in Spain"
x = re.findall("Portugal", txt)
print(x)

search() 函数

search() 函数在字符串中搜索匹配项,如果有匹配项,则返回一个 Match 对象。如果有多个匹配项,只会返回第一个匹配项:

示例:搜索字符串中的第一个空格字符:

import re

txt = "The rain in Spain"
x = re.search("\s", txt) print("第一个空格字符位于位置:", x.start())

如果没有找到匹配项,则返回值为 None:

示例:进行一个不会返回匹配项的搜索:

import re

txt = "The rain in Spain"
x = re.search("Portugal", txt)
print(x)

split() 函数

split() 函数返回一个列表,其中字符串已在每个匹配项处拆分:

示例:在每个空格字符处拆分:

import re

txt = "The rain in Spain"
x = re.split("\s", txt)
print(x)

您可以通过指定 maxsplit 参数来控制出现的次数:

示例:仅在第一个匹配项处拆分字符串:

import re

txt = "The rain in Spain"
x = re.split("\s", txt, 1)
print(x)

sub() 函数

sub() 函数用您选择的文本替换匹配项:

示例:用数字 9 替换每个空格字符:

import re

txt = "The rain in Spain"
x = re.sub("\s", "9", txt)
print(x)

您可以通过指定 count 参数来控制替换的次数:

示例:替换前两个匹配项:

import re

txt = "The rain in Spain"
x = re.sub("\s", "9", txt, 2)
print(x)

Match 对象

Match 对象是一个包含有关搜索和结果的信息的对象。

注意:如果没有匹配项,将返回值 None,而不是 Match 对象。

示例:执行一个将返回 Match 对象的搜索:

import re

txt = "The rain in Spain"
x = re.search("ai", txt)
print(x) # 这将打印一个对象

Match 对象具有属性和方法,用于检索有关搜索和结果的信息:

  • .span() 返回一个包含匹配项的起始位置和结束位置的元组。
  • .string 返回传递给函数的字符串。
  • .group() 返回字符串中存在匹配项的部分。

示例:打印第一个匹配项的位置(起始位置和结束位置)。正则表达式查找以大写字母 "S" 开头的任何单词:

import re

txt = "The rain in Spain"
x = re.search(r"\bS\w+", txt)
print(x.span())

示例:打印传递给函数的字符串:

import re

txt = "The rain in Spain"
x = re.search(r"\bS\w+", txt)
print(x.string)

示例:打印存在匹配项的字符串部分。正则表达式查找以大写字母 "S" 开头的任何单词:

import re

txt = "The rain in Spain"
x = re.search(r"\bS\w+", txt)
print(x.group())

最后

为了方便其他设备和平台的小伙伴观看往期文章:公众号搜索Let us Coding,或者扫描下方二维码,关注公众号,即可获取最新文章。

看完如果觉得有帮助,欢迎点赞、收藏关注

Python 正则表达式(RegEx)指南的更多相关文章

  1. Python 正则表达式(RegEx)

    版权所有,未经许可,禁止转载 章节 Python 介绍 Python 开发环境搭建 Python 语法 Python 变量 Python 数值类型 Python 类型转换 Python 字符串(Str ...

  2. Python正则表达式基础指南

    1. 正则表达式基础 1.1. 简单介绍 正则表达式并不是Python的一部分.正则表达式是用于处理字符串的强大工具,拥有自己独特的语法以及一个独立的处理引擎,效率上可能不如str自带的方法,但功能十 ...

  3. Python正则表达式完全指南(上)

    正则表达式处理文本有如疾风扫秋叶,绝大部分编程语言都内置支持正则表达式,它应用在诸如表单验证.文本提取.替换等场景.爬虫系统更是离不开正则表达式,用好正则表达式往往能收到事半功倍的效果. 介绍正则表达 ...

  4. Python正则表达式指南(转)

    目录 Python正则表达式指南(转) 0.防走丢 1. 正则表达式基础 1.1. 简单介绍 1.2. 数量词的贪婪模式与非贪婪模式 1.3. 反斜杠的困扰 1.4. 匹配模式 2. re模块 2.1 ...

  5. 转:C++ Boost/tr1 Regex(正则表达式)快速指南

    C++ Boost/tr1 Regex(正则表达式)快速指南 正则表达式自Boost 1.18推出,目前已经成为C++11(tr1)的标准部分. 本文以Boost 1.39正则表达式为基础,应该广泛适 ...

  6. [转] Python正则表达式指南

    本文介绍了Python对于正则表达式的支持,包括正则表达式基础以及Python正则表达式标准库的完整介绍及使用示例.本文的内容不包括如何编写高效的正则表达式.如何优化正则表达式,这些主题请查看其他教程 ...

  7. 转:Python正则表达式指南

    本文介绍了Python对于正则表达式的支持,包括正则表达式基础以及Python正则表达式标准库的完整介绍及使用示例.本文的内容不包括如何编写高效的正则表达式.如何优化正则表达式,这些主题请查看其他教程 ...

  8. 更强大的python正则表达式模块 -- regex

    python内置的正则表达库re比较弱,而且似乎在好几年里都没太大的变化. 这里介绍这个python模块regex,实现了更多方便好用的功能. 比如:\p{han} 可以匹配汉字, \p{Latin} ...

  9. 比较详细Python正则表达式操作指南(re使用)

    比较详细Python正则表达式操作指南(re使用) Python 自1.5版本起增加了re 模块,它提供 Perl 风格的正则表达式模式.Python 1.5之前版本则是通过 regex 模块提供 E ...

  10. Python天天美味(15) - Python正则表达式操作指南(re使用)(转)

    http://www.cnblogs.com/coderzh/archive/2008/05/06/1185755.html 简介 Python 自1.5版本起增加了re 模块,它提供 Perl 风格 ...

随机推荐

  1. 「学习笔记」FHQ-treap

    FHQ-treap,即无旋 treap,又称分裂合并 treap,支持维护序列,可持久化等特性. FHQ-treap 有两个核心操作,分裂 与 合并.通过这两个操作,在很多情况下可以比旋转 treap ...

  2. 关于quartus II的导入以前的工程,QSF文件出现的错误的解决方案。

    在有时候打开以前的工程,或者别人做好的例程会遇到一些报错信息.具体报错信息如下: 报错信息语句行: 在文件QSF文件中有几行出错,显示错误读取,即不能打开工程.打开文件发现该几行的PIN 使能信号处于 ...

  3. Oracle 11gR2 单实例 For linux6

    第一章         准备工作 1.1   系统硬件和软件环境检查 Ø  物理内存至少1G # grep MemTotal /proc/meminfo Ø  swap物理内存小于2G时设置为物理内存 ...

  4. 彻底弄懂js中this指向(包含js绑定、优先级、面试题详解)

    为什么要使用this 在javascript中,this可谓是无处不在,它可以用来指向某些元素.对象,在合适的地方使用this,能让我们减少无用代码的编写 var user = {   name: & ...

  5. npm与package.json的联系

    在nodejs编写的脚手架项目中,npm是不可缺少的包管理工具,当使用npm初始化时,会生成package.json文件来对项目进行整体的管理和描述   以下是新建的练习项目中package.json ...

  6. Godot无法响应鼠标点击等输入事件时,检查这些内容

    注:本文以Godot 4.0 为基准,可能其他版本也能参考. 这是我用C#写项目时发现的,可能和gdscript使用者遇到的问题有一定区别. 如果你用Godot制作的游戏无法响应鼠标点击等输入事件,请 ...

  7. 【Python进阶-PyQt5】00PyQt5简介

    0.图形用户界面-开发选择 在Python基础的教程中,我们程序的用户交互界面都是运行窗口.这个运行窗口对于我们编程者来说直观明了,但是对于一些相对复杂的程序,用户使用上就会变得十分麻烦.所以,我们要 ...

  8. Unity 性能优化之Shader分析处理函数ShaderUtil.HasProceduralInstancing: 深入解析与实用案例

    Unity 性能优化之Shader分析处理函数ShaderUtil.HasProceduralInstancing: 深入解析与实用案例 点击封面跳转到Unity国际版下载页面 简介 在Unity中, ...

  9. GIS中的ROI文件可否由.xml格式转为.roi格式?

      本文介绍在ENVI软件中,将用户自行绘制的.xml格式的感兴趣区(ROI)文件转换为.roi格式的方法.   对于ENVI软件,其在早期版本中,默认将用户所绘制的感兴趣区文件保存为.roi格式:而 ...

  10. 一文弄懂TypeScript中的混合

    1.前言 由于TypeScrip中的类不支持多继承,所以引入了混合(Mixin)的特性,可以间接实现继承的效果. 2.正文 // 声明一个汽车类Vehicle,它有drive方法 class Vehi ...