脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Python - python 正则表达式如何实现重叠匹配

python 正则表达式如何实现重叠匹配

2022-07-14 16:09Dragon水魅 Python

这篇文章主要介绍了python 正则表达式如何实现重叠匹配,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

正则表达式实现重叠匹配

?
1
2
3
4
import regex
string = '100101010001'
str_re = '101'
print(regex.findall(str_re, string, overlapped=True))

python 正则表达式如何实现重叠匹配

普通的re库匹配,只能匹配一个’101’。

正则表达式与正则匹配

正则表达式

正则表达式可理解为对数据筛选的表达式,是有限个原子和元字符组成。

原子:基本组成单位,每个表达式至少有一个原子

普通字符组成原子  

非打印字符组成原子

(不打印在输出台的字符)

\n:换行

\t:tab退格符

通用字符组成原子

\w:匹配任意字母、数字、下划线

\W:与\w相反

\d:匹配任意十进制数

\D:与\d相反

\s:匹配任意空白字符,如空格、换行、缩进

\S:与\s相反

原子表组成原子

一组原子组成一个表,由[]声明

表内原子优先级相等,但内容只出现依次

若原子表以 ^ 开头,则表示取反

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#普通字符组成原子
pat1 = "abcd"
 
#非打印字符组成原子
pat2 = "\n"
 
#通用字符做原子
pat3 = "\w"
 
#原子表组成原子
pat4 = "py[abc]"
#可以匹配pya,pyb,pyc,但匹配pyab等原子表重复出现的情况失败
 
#原子表开头带 ^ 表示取反
pat5 = "py[^abc]"
#第三个位置匹配除了a,b,c外的任意一个字符

元字符:正则表达式中具有特殊含义的字符

. 匹配任意字符,除了换行符
^ 匹配字符串开始的位置
$ 匹配字符串结束的位置,当出现多组符合的匹配时,返回字符串最后的那组匹配
* 匹配 0,1,n 次前面的原子【贪婪模式:尽可能多的匹配】
? 匹配 0,1 次前面的原子【懒惰模式:精确匹配】
+ 匹配 1,n 次前面的原子
{ j } 前面的原子出现 j 次
{ j , } 前面的原子至少出现 j 次
{ j , k } 前面的原子至少出现 j 次,至多出现 k 次
i | j 匹配 i 或 j ,若 i 与 j 同时出现,匹配 i
( ) 组,限制这组数据的组合如()内所描述一样,只返回符合括号内描述的内容

模式修正符

即函数中 flag 位置的参数,在不改变正则表达式的情况下改变其含义,调整匹配结果。

re.I 匹配时忽略大小写
re.M 多行匹配
re.L 本地化识别匹配
re.U 根据unicon字符匹配,影响\w \W
re.S 匹配包括换行符

正则匹配

正则表达式是对字符串进行模糊匹配,其中一个应用为正则匹配。正则匹配是python爬虫的一个使用技术,用于在爬取的文本信息中提取目标信息。

正则匹配常用的函数:(调用正则表达式模块re)

  • re.search(pat, str[, flag]):扫描字符串str,返回pat的位置(第一次成功匹配的),flag用于控制正则表达式的匹配方式
?
1
2
3
4
import re
str = 'python'
pat = 'pytho[a-n]'
print(re.search(pat, str))
  • re.match(pat, str[, flag]):扫描字符串str开始的位置,返回pat的位置(第一次成功匹配的),flag用于控制正则表达式的匹配方式【若开始就不符合则结束,返回none】
?
1
2
3
4
5
6
import re
str_1 = 'hello world'
str_2 = 'world hello'
pat = 'world'
print(re.match(pat, str_1))
print(re.match(pat, str_2))
  • re.complie(pat[, flag]):编译正则表达式pat,返回正则表达式对象
  • findall(str[, pos[, endpos]]):匹配所有,用列表返回string中所有匹配到的子串【不止第一次】,pos和endpos可指定在string中的起始位置
  • re.complie(pat).findall(str):全局匹配函数,匹配str中所有符合pat的子串,装入一个列表返回结果
?
1
2
3
4
5
import re
str = "hello world hello world hello world"
pat = "hello"
print(re.complie(pat).findall(str))
print(re.complie(pat).findall(str, 5, 15))
  • re.sub(pat, repl, str[, count[, flag]]):替换字符串中的匹配项【清洗数据】,可用count指定最大替换次数
?
1
2
3
4
5
import re
str = "400-823-823"
pat = "-"
#短横改空格,最大替换次数2
str_new = re.sub(pat, " ", str, count=2)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/qq_43650934/article/details/107287416

延伸 · 阅读

精彩推荐
  • PythonPython CSV模块使用实例

    Python CSV模块使用实例

    这篇文章主要介绍了Python CSV模块使用实例,本文将举几个例子来介绍一下Python的CSV模块的使用方法,包括reader、writer、DictReader、DictWriter.register_dialect等,需要...

    脚本之家4532020-06-02
  • PythonPython决策树分类算法学习

    Python决策树分类算法学习

    这篇文章主要为大家详细介绍了Python决策树分类算法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    lsldd7892020-12-28
  • Python使用Python实现跳一跳自动跳跃功能

    使用Python实现跳一跳自动跳跃功能

    这篇文章主要介绍了使用Python实现跳一跳自动跳跃功能,本文图文并茂通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考...

    数据森麟10632021-08-07
  • Python利用python实现简易版的贪吃蛇游戏(面向python小白)

    利用python实现简易版的贪吃蛇游戏(面向python小白)

    这篇文章主要给大家介绍了关于如何利用python实现简易版的贪吃蛇游戏的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的...

    python高效编程6672021-05-10
  • PythonPython多线程下载文件的方法

    Python多线程下载文件的方法

    这篇文章主要介绍了Python多线程下载文件的方法,涉及Python多线程及文件操作的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下...

    speedmancs11582020-07-21
  • PythonPython绘制堆叠柱状图的实例

    Python绘制堆叠柱状图的实例

    今天小编就为大家分享一篇Python绘制堆叠柱状图的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    程序小学生14122021-08-05
  • PythonPython+MySQL随机试卷及答案生成程序的示例代码

    Python+MySQL随机试卷及答案生成程序的示例代码

    这篇文章主要介绍了Python+MySQL随机试卷及答案生成程序的示例代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友...

    疯狂的机器人8172021-08-31
  • Pythonpython将txt文件读取为字典的示例

    python将txt文件读取为字典的示例

    今天小编就为大家分享一篇python将txt文件读取为字典的示例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    weixin_3901204714482021-05-06