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外的任意一个字符

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

.^$*?+{ j }{ j , }{ j , k }i | j( )
匹配任意字符,除了换行符
匹配字符串开始的位置
匹配字符串结束的位置,当出现多组符合的匹配时,返回字符串最后的那组匹配
匹配 0,1,n 次前面的原子【贪婪模式:尽可能多的匹配】
匹配 0,1 次前面的原子【懒惰模式:精确匹配】
匹配 1,n 次前面的原子
前面的原子出现 j 次
前面的原子至少出现 j 次
前面的原子至少出现 j 次,至多出现 k 次
匹配 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)

以上为个人经验,希望能给大家一个参考,也希望大家多多支持易知道(ezd.cc)。

推荐阅读

    ps重合复制快捷键|ps重叠快捷键

    ps重合复制快捷键|ps重叠快捷键,,1. ps重叠快捷键1.首先在PS软件中,点击“文件”,弹出的菜单选择“打开”,并选择一张图片作为前景图片。2.再

    电脑硬盘重亲分区|硬盘分区重叠

    电脑硬盘重亲分区|硬盘分区重叠,,硬盘分区重叠你这个问题用数据恢复精灵这个软件能够轻松解决。运行数据恢复精灵,进入“恢复丢失的分区”

    正则表达式不包含

    正则表达式不包含,正则,数字,字符串,正则表达式,位置,下划线,正则表达式不管是做哪方面开发的朋友都会使用到,但是有好多人不太懂正则正则表达式

    PHP正则表达式合集

    PHP正则表达式合集,输入,正则表达式,验证,字符串,数字,字符,正则表达式,又称规则表达式,英文名为Regular Expression,在代码中常简写为regex、rege

    php 正则表达式贪婪模式,非贪婪模式

    php 正则表达式贪婪模式,非贪婪模式,贪婪,模式,正则表达式匹配模式分为贪婪非贪婪两种。这两种模式是影响存在限定词修饰的子表达式的匹配

    php 正则表达式贪婪模式,非贪婪模式

    php 正则表达式贪婪模式,非贪婪模式,贪婪,模式,正则表达式匹配模式分为贪婪非贪婪两种。这两种模式是影响存在限定词修饰的子表达式的匹配

    js正则表达式

    js正则表达式,字符,正则表达式,字符串,模式,表达式,数字,  js正则表达式中有很多特殊的字符可能有些人并不知道是什么含义,下面我们就来具体介