python正则表达式实现重叠匹配的知识点有哪些
Admin 2022-09-08 群英技术资讯 923 次浏览
这篇文章我们来了解“python正则表达式实现重叠匹配的知识点有哪些”的内容,小编通过实际的案例向大家展示了操作过程,简单易懂,有需要的朋友可以参考了解看看,那么接下来就跟随小编的思路来往下学习吧,希望对大家学习或工作能有帮助。

import regex string = '100101010001' str_re = '101' print(regex.findall(str_re, string, overlapped=True))

普通的re库匹配,只能匹配一个’101’。
正则表达式可理解为对数据筛选的表达式,是有限个原子和元字符组成。
原子:基本组成单位,每个表达式至少有一个原子
| 普通字符组成原子 | |
|---|---|
非打印字符组成原子 (不打印在输出台的字符) |
\n:换行 \t:tab退格符 |
| 通用字符组成原子 | \w:匹配任意字母、数字、下划线 \W:与\w相反 \d:匹配任意十进制数 \D:与\d相反 \s:匹配任意空白字符,如空格、换行、缩进 \S:与\s相反 |
| 原子表组成原子 | 一组原子组成一个表,由[]声明 表内原子优先级相等,但内容只出现依次 若原子表以 ^ 开头,则表示取反 |
#普通字符组成原子 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用于控制正则表达式的匹配方式import re str = 'python' pat = 'pytho[a-n]' print(re.search(pat, str))
re.match(pat, str[, flag]):扫描字符串str开始的位置,返回pat的位置(第一次成功匹配的),flag用于控制正则表达式的匹配方式【若开始就不符合则结束,返回none】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的子串,装入一个列表返回结果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指定最大替换次数import re str = "400-823-823" pat = "-" #短横改空格,最大替换次数2 str_new = re.sub(pat, " ", str, count=2)
关于“python正则表达式实现重叠匹配的知识点有哪些”的内容今天就到这,感谢各位的阅读,大家可以动手实际看看,对大家加深理解更有帮助哦。如果想了解更多相关内容的文章,关注我们,群英网络小编每天都会为大家更新不同的知识。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
有没有什么内容形式,比小视频更小,比普通图片更丰富?有,GIF动态图就是其中一种形式。本文将为大家介绍如何通过Python实现一个傻瓜式的gif生成工具,感兴趣的可以了解一下
在给计算机编程时,经常需要将数据告诉计算机,会将二进制数直接输入计算机, 但二进制数的特点是,只有0和1两种记数,位数比较长。如果用二进制数写程序,只要这个数比较大, 位数就会很长,很容易写错,同时二进制并不直观,写出来的数是否正确,需要转换才能知道。
整个Spark 框架模块包含:Spark Core、 Spark SQL、 Spark Streaming、 Spark GraphX、 Spark MLlib,而后四项的能力都是建立在核心引擎之上。Spark Core:Spark的核心,Spark核心功能均由Spark Core模块提供...
本篇文章给大家带来了关于Python的相关知识,每个ndarray都有一个关联的数据类型(dtype)对象。这个数据类型对象(dtype)告诉我们数组的布局。下面将通过示例详细讲讲NumPy的
本文给大家分享的是python实现计算器的内容,下文会使用Python tkinter来做一个简易的计算器,实现效果如下。那么接下来我们就来具体的了解看看这是怎样实现的吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008