【Python 基础教程】优雅的拿捏正则表达式

简介: 【Python 基础教程】优雅的拿捏正则表达式

💓前言


今天带给大家一个非常强大的字符串处理库。学好之后可以很轻松的解析掉一个格式化文档,在爬虫数据分析有着很广泛的应用。当然这篇文章不仅仅使用与Python语言学习者学习,而是适用于各种语言学习者学习。正则表达式在每一门语言中应该都有应用,并且在每一门语言中不会有太大的差异,最多就是换个小马甲。


👻什么是正则表达式


😻概念:


大家应该都听说过数据分析这一门学科,在数据分析中需要按照某种格式处理某些数据,使得数据有条有理,经过数据分析处理过的数据往往更有利于检索、合并、显示。对数据进行数据分析的话可能会经过很多道步骤进行处理,进行每一步处理的时候都有一个共同的特性,就是特征的提取,或者说根据特征进行删除、替换。而在提取的时候使用的方式往往就是匹配。正则表达式通常被用来检索、替换那些符合某个模式(规则)的文本。正则表达式又称规则表达式。(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的一个概念。许多程序设计语言都支持利用正则表达式进行字符串操作。正则表达式这个概念最初是由Unix中的工具软件普及开的。正则表达式通常缩写成“regex”,单数有regexp、regex,复数有regexps、regexes、regexen。可能看概念比较懵逼,大家继续往下看即可,接下来咱们在需求中学会正则表达式。


😻各种语言支持正则表达式语法的情况:


53ecb1b9c0454db9ac146c3d5f32b993.png

👻修饰符与模式匹配


😻函数标志位参数


这个就是调用search或者findall函数时传进去的参数flag


1667996967838.png


😻匹配模式标志符


字母和数字表示他们自身。一个正则表达式模式中的字母和数字匹配同样的字符串。

多数字母和数字前加一个反斜杠时会拥有不同的含义。

标点符号只有被转义时才匹配自身,否则它们表示特殊的含义。

反斜杠本身需要使用反斜杠转义。


1667997000360.png

1667997035155.png

1667997059228.png


😻常用的模式匹配


1667997094371.png

1667997108391.png

👻Python中使用正则表达式


Python作为时下最时髦的语言之一,具有非常强的数据分析功能。天然的支持正则表达式。Python中内置的re包中包含我们需要的函数。使用正则表达式进行模式匹配针对的是字符串。大家不要传其他类型。使用以下函数进行模式匹配后会返回一个对象,我们可以调用该对象的group方法对获取匹配到的结果按匹配模式进行分组 group的参数类型是int型,group(0)代表的是将满足所有匹配模式的串拿出来,group(1)是满足第一个匹配模式的,group(2)是满足第二个匹配模式的......我们会使用()进行分组,也就是说一个()内部就是一个匹配模式。


①match


💥函数原型


re.match(pattern, string, flags=0)
• 1


💥参数说明:


参数 描述
pattern 匹配的正则表达式
string 要匹配的字符串。
flags 标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。



匹配成功re.match方法返回一个匹配的对象,否则返回None。


💥函数作用


尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match()就返回none。
• 1


我们可以使用group(num) 或 groups() 匹配对象函数来获取匹配表达式。


mystr="我的账号是:9999,密码是:000,我的账号是:8080,密码是:9090,"
mystr1="9999,9999我的账号是:99\n99,密码是:000,我的账号是:8\n080,密码是:90\n90,"
import re
print(re.match("9999",mystr))
# 等价于group(0)将匹配的段落拿出来
print(re.match("9999",mystr1).group())
# 起始终止位置的索引
print(re.match("9999",mystr1).span())


②search


💥函数原型


re.search(pattern, string, flags=0)
• 1


💥参数说明:


参数 描述
pattern 匹配的正则表达式
string 要匹配的字符串。
flags 标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。



匹配成功re.search方法返回一个匹配的对象,否则返回None。


💥函数作用


re.search 扫描整个字符串并返回第一个成功的匹配。
re.match 只匹配字符串的开始,如果字符串开始不符合正则表达式,
则匹配失败,函数返回 None,而 re.search 匹配整个字符串,直到找到一个匹配。


mystr="我的银行卡账号是:9999,密码是:000,我的学习通账号是:8080,密码是:9090,"
mystr1="9999,9999我的银行卡账号是:99\n99,密码是:000,我的学习通账号是:8\n080,密码是:90\n90,"
import re
print(re.search("9999",mystr).group())
print(re.search("9999",mystr1).group())
print(re.search("9999",mystr1).span())


③sub


💥函数原型


re.sub(pattern, repl, string, count=0, flags=0)
• 1


💥参数说明:


pattern : 正则中的模式字符串。
repl : 替换的字符串,也可为一个函数。
string : 要被查找替换的原始字符串。
count : 模式匹配后替换的最大次数,默认 0 表示替换所有的匹配。
flags : 编译时用的匹配模式,数字形式。
前三个为必选参数,后两个为可选参数。
默认全盘替换,可以指定count指定替换个数。


匹配成功re.search方法返回一个匹配的对象,否则返回None。


💥函数作用


用于替换字符串中的匹配项。


import re
print(re.sub("9999","xxxx",mystr1))
# 将匹配的数字乘于 2
def double(matched):
    value = int(matched.group('value'))
    return str(value * 2)
s = 'A23G4HFD567'
print(re.sub('(?P<value>\d+)', double, s))


④cpmpile


💥函数原型


re.compile(pattern[, flags])
• 1


💥参数说明:


pattern : 一个字符串形式的正则表达式
flags 可选,表示匹配模式,比如忽略大小写,多行模式等,具体参数为:
    re.I 忽略大小写
    re.L 表示特殊字符集 \w, \W, \b, \B, \s, \S 依赖于当前环境
    re.M 多行模式
    re.S 即为' . '并且包括换行符在内的任意字符(' . '不包括换行符)
    re.U 表示特殊字符集 \w, \W, \b, \B, \d, \D, \s, \S 依赖于 Unicode 字符属性数据库
    re.X 为了增加可读性,忽略空格和' # '后面的注释


匹配成功re.search方法返回一个匹配的对象,否则返回None。


💥函数作用


compile 函数用于编译正则表达式,生成一个正则表达式( Pattern )对象
供 match() 和 search() 这两个函数使用。



import re
mystr="我的银行卡账号是:AASAa,密码是:000,我的学习通账号是:8080,密码是:9090,"
# 使用compile进行初始化
r1=re.compile("aaSaa",re.I)
print(r1.search(mystr).group())
# 不使用compile进行初始化
print(re.search("aaSaa",mystr))


⑤findall ----- (最常用)


💥函数原型


re.findall(pattern, string, flags=0)
pattern.findall(string[, pos[, endpos]])


💥参数说明:


pattern 匹配模式。
string 待匹配的字符串。
pos 可选参数,指定字符串的起始位置,默认为 0。
endpos 可选参数,指定字符串的结束位置,默认为字符串的长度。


匹配成功re.search方法返回一个匹配的对象,否则返回None。


💥函数作用(重要程度:☆☆☆☆☆)


在字符串中找到正则表达式所匹配的所有子串,并返回一个列表,
如果有多个匹配模式,则返回元组列表,如果没有找到匹配的,则返回空列表。
match 和 search 是匹配一次 findall 匹配所有。


import re
# 单匹配模式
mystr="我的9999银行9999卡账号是:AASAa,密码是:000,我的9999学习通账号是:8080,密码是:9090,"
ls=re.findall("9999",mystr)
print(ls)
# 多匹配模式
result = re.findall(r'(\w+)=(\d+)', 'set width=200px and height=100px')
print(result)


⑥finditer


💥函数原型


re.finditer(pattern, string, flags=0)
• 1


💥参数说明:


pattern 匹配的正则表达式
string  要匹配的字符串。
flags 标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。


匹配成功re.search方法返回一个匹配的对象,否则返回None。


💥函数作用


和 findall 类似,在字符串中找到正则表达式所匹配的所有子串,并把它们作为一个迭代器返回。


import re
it = re.finditer(r"\d+","12a32bc43jf3") 
for match in it: 
    print (match.group() )


⑦split


💥函数原型


re.split(pattern, string[, maxsplit=0, flags=0])
• 1


💥参数说明:


参数 描述
pattern 匹配的正则表达式
string 要匹配的字符串。
maxsplit 分割次数,maxsplit=1 分割一次,默认为 0,不限制次数。
flags 标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等。


💥函数作用


split 方法按照能够匹配的子串将字符串分割后返回列表 
与字符串中的split函数功能灰常类似
默认将所有可匹配的位置都进行切割


import re
# 单匹配模式
mystr="我的9999银行9999卡账号是:AASAa,密码是:000,我的9999学习通账号是:8080,密码是:9090,"
ls=re.split("9999",mystr,maxsplit=2)
print(ls)


正则表达式说到底也就是根据一个字符串的规则去匹配另外一个目标串,经过对目标串进行解析、替换得到想要的结果。
目录
相关文章
|
2天前
|
存储 Python
SciPy 教程 之 SciPy 稀疏矩阵 4
SciPy 教程之 SciPy 稀疏矩阵 4:介绍稀疏矩阵的概念、类型及其在科学计算中的应用。SciPy 的 `scipy.sparse` 模块提供了处理稀疏矩阵的工具,重点讲解了 CSC 和 CSR 两种格式,并通过示例演示了如何创建和操作 CSR 矩阵。
20 3
|
3天前
|
存储 Python
SciPy 教程 之 SciPy 稀疏矩阵 2
SciPy教程之SciPy稀疏矩阵2:介绍稀疏矩阵的概念、应用场景及scipy.sparse模块的使用。重点讲解CSC和CSR两种稀疏矩阵类型及其常用方法,如data属性和count_nonzero()方法。
23 4
|
10天前
|
Python
SciPy 教程 之 SciPy 模块列表 6
SciPy教程之常量模块介绍:涵盖公制、二进制(字节)、质量、角度、时间、长度、压强、体积、速度、温度、能量、功率及力学单位。示例展示了角度单位转换为弧度的几个常用常量。
15 7
|
10天前
|
Python
SciPy 教程 之 SciPy 模块列表 7
`scipy.constants` 模块提供了常用的时间单位转换为秒数的功能。例如,`constants.hour` 返回 3600.0 秒,表示一小时的秒数。其他常用时间单位包括分钟、天、周、年和儒略年。
14 6
|
7天前
|
Python
SciPy 教程 之 SciPy 模块列表 13
SciPy教程之SciPy模块列表13:单位类型。常量模块包含多种单位,如公制、二进制(字节)、质量、角度、时间、长度、压强、体积、速度、温度、能量、功率和力学单位。示例代码展示了如何使用`constants`模块获取零摄氏度对应的开尔文值(273.15)和华氏度与摄氏度的转换系数(0.5556)。
11 1
|
9天前
|
Python
SciPy 教程 之 SciPy 模块列表 9
SciPy教程之常量模块介绍,涵盖多种单位类型,如公制、质量、角度、时间、长度、压强等。示例展示了如何使用`scipy.constants`模块查询不同压强单位对应的帕斯卡值,包括atm、bar、torr、mmHg和psi。
10 1
|
9天前
|
Python
SciPy 教程 之 SciPy 模块列表 8
SciPy教程之常量模块单位类型介绍。该模块包含多种单位,如公制、质量、角度、时间、长度、压强、体积、速度、温度、能量、功率和力学单位。示例展示了部分长度单位的转换值,例如英寸、英尺、海里等。
12 1
|
11天前
|
知识图谱 Python
SciPy 教程 之 SciPy 模块列表 5
本教程介绍SciPy常量模块中的单位类型,涵盖公制、质量、时间、长度等单位。示例代码展示了如何使用`scipy.constants`模块获取不同质量单位的千克值,如公吨、磅、盎司、原子质量单位等。
11 1
|
1天前
|
算法 Python
SciPy 教程 之 SciPy 图结构 1
SciPy 图结构教程介绍了图的基本概念及其在算法中的应用。图由节点和边组成,节点代表对象,边表示对象间的连接。SciPy 的 `scipy.sparse.csgraph` 模块提供了处理图结构的工具。邻接矩阵用于表示节点间的连接关系,分为有向图和无向图两种类型。无向图的边是双向的,而有向图的边则有明确的方向。
8 0
|
1天前
|
存储 Python
SciPy 教程 之 SciPy 稀疏矩阵 5
SciPy 稀疏矩阵教程介绍了稀疏矩阵的概念及其在科学计算中的应用。SciPy 的 `scipy.sparse` 模块提供了处理稀疏矩阵的功能,主要使用 CSC(压缩稀疏列)和 CSR(压缩稀疏行)两种格式。通过示例展示了如何创建 CSR 矩阵、查看非零元素及转换为 CSC 格式。
10 0