【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)


正则表达式说到底也就是根据一个字符串的规则去匹配另外一个目标串,经过对目标串进行解析、替换得到想要的结果。
相关文章
|
10天前
|
JSON 数据可视化 API
Python 中调用 DeepSeek-R1 API的方法介绍,图文教程
本教程详细介绍了如何使用 Python 调用 DeepSeek 的 R1 大模型 API,适合编程新手。首先登录 DeepSeek 控制台获取 API Key,安装 Python 和 requests 库后,编写基础调用代码并运行。文末包含常见问题解答和更简单的可视化调用方法,建议收藏备用。 原文链接:[如何使用 Python 调用 DeepSeek-R1 API?](https://apifox.com/apiskills/how-to-call-the-deepseek-r1-api-using-python/)
|
21天前
|
IDE 测试技术 项目管理
【新手必看】PyCharm2025 免费下载安装配置教程+Python环境搭建、图文并茂全副武装学起来才嗖嗖的快,绝对最详细!
PyCharm是由JetBrains开发的Python集成开发环境(IDE),专为Python开发者设计,支持Web开发、调试、语法高亮、项目管理、代码跳转、智能提示、自动完成、单元测试和版本控制等功能。它有专业版、教育版和社区版三个版本,其中社区版免费且适合个人和小型团队使用,包含基本的Python开发功能。安装PyCharm前需先安装Python解释器,并配置环境变量。通过简单的步骤即可在PyCharm中创建并运行Python项目,如输出“Hello World”。
193 13
【新手必看】PyCharm2025 免费下载安装配置教程+Python环境搭建、图文并茂全副武装学起来才嗖嗖的快,绝对最详细!
|
2月前
|
数据可视化 DataX Python
Seaborn 教程-绘图函数
Seaborn 教程-绘图函数
86 8
|
2月前
Seaborn 教程-主题(Theme)
Seaborn 教程-主题(Theme)
154 7
|
2月前
|
Python
Seaborn 教程-模板(Context)
Seaborn 教程-模板(Context)
56 4
|
2月前
|
数据可视化 Python
Seaborn 教程
Seaborn 教程
63 5
|
3月前
|
Python
SciPy 教程 之 Scipy 显著性检验 9
SciPy 教程之 Scipy 显著性检验第9部分,介绍了显著性检验的基本概念、作用及原理,通过样本信息判断假设是否成立。着重讲解了使用scipy.stats模块进行显著性检验的方法,包括正态性检验中的偏度和峰度计算,以及如何利用normaltest()函数评估数据是否符合正态分布。示例代码展示了如何计算一组随机数的偏度和峰度。
44 1
|
3月前
|
BI Python
SciPy 教程 之 Scipy 显著性检验 8
本教程介绍SciPy中显著性检验的应用,包括如何利用scipy.stats模块进行显著性检验,以判断样本与总体假设间的差异是否显著。通过示例代码展示了如何使用describe()函数获取数组的统计描述信息,如观测次数、最小最大值、均值、方差等。
47 1
|
3月前
|
数据采集 数据可视化 数据挖掘
深入浅出:使用Python进行数据分析的基础教程
【10月更文挑战第41天】本文旨在为初学者提供一个关于如何使用Python语言进行数据分析的入门指南。我们将通过实际案例,了解数据处理的基本步骤,包括数据的导入、清洗、处理、分析和可视化。文章将用浅显易懂的语言,带领读者一步步掌握数据分析师的基本功,并在文末附上完整的代码示例供参考和实践。
|
3月前
|
Python
SciPy 教程 之 Scipy 显著性检验 6
显著性检验是统计学中用于判断样本与总体假设间是否存在显著差异的方法。SciPy的scipy.stats模块提供了执行显著性检验的工具,如T检验,用于比较两组数据的均值是否来自同一分布。通过ttest_ind()函数,可以获取两样本的t统计量和p值,进而判断差异是否显著。示例代码展示了如何使用该函数进行T检验并输出结果。
48 1