PYTHON正则表达式 深入浅出

合集下载

python 正则表达式判断

python 正则表达式判断

python 正则表达式判断摘要:1.Python 正则表达式的概念2.Python 正则表达式的语法3.Python 正则表达式的应用4.Python 正则表达式的判断方法正文:一、Python 正则表达式的概念正则表达式(Regular Expression,简称regex)是一种用于匹配字符串模式的字符集,通常用于文本搜索和数据提取等场景。

Python 作为一种广泛应用的编程语言,也提供了正则表达式的支持。

二、Python 正则表达式的语法Python 中的正则表达式主要通过`re`模块进行操作。

以下是一些常用的正则表达式语法:1.`.`:匹配任意字符(除了换行符)。

2.`*`:匹配前面的字符0 次或多次。

3.`+`:匹配前面的字符1 次或多次。

4.`?`:匹配前面的字符0 次或1 次。

5.`{n}`:匹配前面的字符n 次。

6.`{n,}`:匹配前面的字符n 次或多次。

7.`{n,m}`:匹配前面的字符n 到m 次。

8.`[abc]`:匹配方括号内的任意一个字符(a、b 或c)。

9.`[^abc]`:匹配除方括号内字符以外的任意字符。

10.`(pattern)`:捕获括号内的模式,并将其存储以供以后引用。

11.`|`:表示或(or),匹配两个模式之一。

三、Python 正则表达式的应用Python 正则表达式广泛应用于文本处理、数据分析等场景,例如:验证邮箱地址、提取网页链接、筛选特定字符等。

四、Python 正则表达式的判断方法在Python 中,我们可以使用`re`模块的函数来判断字符串是否符合正则表达式的规则。

以下是一些常用的判断方法:1.`re.match(pattern, string)`:从字符串的开头开始匹配,如果匹配成功则返回一个匹配对象,否则返回None。

2.`re.search(pattern, string)`:在整个字符串中搜索匹配,如果匹配成功则返回一个匹配对象,否则返回None。

Python系列之正则表达式详解

Python系列之正则表达式详解

Python系列之正则表达式详解Python 正则表达式模块 (re) 简介Python 的 re 模块(Regular Expression 正则表达式)提供各种正则表达式的匹配操作,和 Perl 脚本的正则表达式功能类似,使⽤这⼀内嵌于 Python 的语⾔⼯具,尽管不能满⾜所有复杂的匹配情况,但⾜够在绝⼤多数情况下能够有效地实现对复杂字符串的分析并提取出相关信息。

Python 会将正则表达式转化为字节码,利⽤ C 语⾔的匹配引擎进⾏深度优先的匹配。

表 1. 正则表达式元字符和语法符号说明实例.表⽰任意字符,如果说指定了 DOTALL 的标识,就表⽰包括新⾏在内的所有字符。

'abc' >>>'a.c' >>>结果为:'abc'^表⽰字符串开头。

'abc' >>>'^abc' >>>结果为:'abc'$表⽰字符串结尾。

'abc' >>>'abc$' >>>结果为:'abc'*, +, ?'*'表⽰匹配前⼀个字符重复 0 次到⽆限次,'+'表⽰匹配前⼀个字符重复 1次到⽆限次,'?'表⽰匹配前⼀个字符重复 0 次到1次'abcccd' >>>'abc*' >>>结果为:'abccc''abcccd' >>>'abc+' >>>结果为:'abccc''abcccd' >>>'abc?' >>>结果为:'abc'*?, +?, ??前⾯的*,+,?等都是贪婪匹配,也就是尽可能多匹配,后⾯加?号使其变成惰性匹配即⾮贪婪匹配'abc' >>>'abc*?' >>>结果为:'ab''abc' >>>'abc??' >>>结果为:'ab''abc' >>>'abc+?' >>>结果为:'abc'{m}匹配前⼀个字符 m 次'abcccd' >>>'abc{3}d' >>>结果为:'abcccd' {m,n}匹配前⼀个字符 m 到 n 次'abcccd' >>> 'abc{2,3}d' >>>结果为:'abcccd' {m,n}?匹配前⼀个字符 m 到 n 次,并且取尽可能少的情况'abccc' >>> 'abc{2,3}?' >>>结果为:'abcc'\对特殊字符进⾏转义,或者是指定特殊序列 'a.c' >>>'a\.c' >>> 结果为: 'a.c'[]表⽰⼀个字符集,所有特殊字符在其都失去特殊意义,只有: ^ - ] \ 含有特殊含义'abcd' >>>'a[bc]' >>>结果为:'ab'|或者,只匹配其中⼀个表达式,如果|没有被包括在()中,则它的范围是整个正则表达式'abcd' >>>'abc|acd' >>>结果为:'abc' ( … )被括起来的表达式作为⼀个分组. findall 在有组的情况下只显⽰组的内容 'a123d' >>>'a(123)d' >>>结果为:'123'(?#...)注释,忽略括号内的内容特殊构建不作为分组 'abc123' >>>'abc(?#fasd)123' >>>结果为:'abc123'(?= …)表达式’…’之前的字符串,特殊构建不作为分组在字符串’ pythonretest ’中 (?=test) 会匹配’pythonre ’(?!...)后⾯不跟表达式’…’的字符串,特殊构建不作为分组如果’ pythonre ’后⾯不是字符串’ test ’,那么(?!test) 会匹配’ pythonre ’(?<=… )跟在表达式’…’后⾯的字符串符合括号之后的正则表达式,特殊构建不作为分组正则表达式’ (?<=abc)def ’会在’ abcdef ’中匹配’def ’(?:)取消优先打印分组的内容'abc' >>>'(?:a)(b)' >>>结果为'[b]'?P<>指定Key'abc' >>>'(?P<n1>a)>>>结果为:groupdict{n1:a}表 2. 正则表达式特殊序列特殊表达式序列说明\A只在字符串开头进⾏匹配。

python正则表达式re.findall 详细解说

python正则表达式re.findall 详细解说

Python正则表达式:`re.findall()`函数的使用re.findall()是Python的正则表达式模块re的一个函数。

这个函数用于查找字符串中所有匹配的子串,并返回一个包含所有匹配结果的列表。

如果没有找到任何匹配的子串,它将返回一个空列表。

re.findall()的语法如下:re.findall(pattern, string, flags=0)参数说明:pattern:一个字符串,包含了你想要匹配的正则表达式。

string:你想要在其中查找匹配项的字符串。

flags:一个可选参数,用于指定正则表达式的标志。

例如,你可以使用re.IGNORECASE来使匹配不区分大小写。

让我们通过一个例子来说明re.findall()的使用:import retext = "The quick brown fox jumps over the lazy dog"pattern = "o"matches = re.findall(pattern, text)print(matches) # 输出:['o', 'o', 'o', 'o']在这个例子中,我们在文本字符串"The quick brown fox jumps over the lazy dog" 中查找所有的'o' 字符,并打印出结果。

re.findall()返回一个列表,其中包含所有匹配的字符'o'。

你也可以使用正则表达式来匹配更复杂的模式。

例如,你可以使用\d+来匹配一个或多个数字:import retext = "The quick brown fox jumps over the lazy dog. The dog is 3 years old."pattern = "\d+"matches = re.findall(pattern, text)print(matches) # 输出:['3']在这个例子中,我们查找文本中所有的数字,并打印出结果。

python正则表达式_深入浅出

python正则表达式_深入浅出
python 的正则表达式 re
延伸阅读:python 的 内建函数 和 subprocess 。此文是本系列的第三篇文章了,和 之前一样,内容出自官方文档,但是会有自己的理解,并非单纯的翻译。所以,如果我理解 有误,欢迎指正,谢谢。
本模块提供了和 Perl 里的正则表达式类似的功能,不关是正则表达式本身还是被搜索 的字符串,都可以是 Unicode 字符,这点不用担心,python 会处理地和 Ascii 字符一样漂 亮。
>>> re.match('<(?P<tagname>\w*)>.*</(?P=tagname)>', '<h1>xxx</h1>') # 这个匹配
<_sre.SRE_Match object at 0xb69588e0>
(?#...)
注释,圆括号里的内容会被忽略。
(?=...)
如果 ... 匹配接下来的字符,才算匹配,但是并不会消耗任何被匹配的字符。例如 Isaac (?=Asimov) 只会匹配后面跟着 'Asimov' 的 'Isaac ',这个叫做“前瞻断言”。 需要后缀匹配
正则表达式使用反斜杆(\)来转义特殊字符,使其可以匹配字符本身,而不是指定其 他特殊的含义。这可能会和 python 字面意义上的字符串转义相冲突,这也许有些令人费 解。比如,要匹配一个反斜杆本身,你也许要用'\\\\'来做为正则表达式的字符串,因为正 则表达式要是\\,而字符串里,每个反斜杆都要写成\\。
如有由 id 或者 name 指定的组存在的话,将会匹配 yes-pattern,否则将会匹配 nopattern,通常情况下 no-pattern 也可以省略。例如:()可以匹配 '<user@>' 和 'user@',但是不会匹配 '<user@'。

python正则表达式详解

python正则表达式详解

python正则表达式详解python 正则表达式详解1. 正则表达式模式模式描述^匹配字符串的开头$匹配字符串的末尾。

.匹配任意字符,除了换⾏符,当re.DOTALL标记被指定时,则可以匹配包括换⾏符的任意字符。

[...]⽤来表⽰⼀组字符,单独列出:[amk] 匹配 'a','m'或'k'[^...]不在[]中的字符:[^abc] 匹配除了a,b,c之外的字符。

re*匹配0个或多个的表达式。

re+匹配1个或多个的表达式。

re?匹配0个或1个由前⾯的正则表达式定义的⽚段,⾮贪婪⽅式re{ n}匹配n个前⾯表达式。

例如,"o{2}"不能匹配"Bob"中的"o",但是能匹配"food"中的两个o。

re{ n,}精确匹配n个前⾯表达式。

例如,"o{2,}"不能匹配"Bob"中的"o",但能匹配"foooood"中的所有o。

"o{1,}"等价于"o+"。

"o{0,}"则等价于"o*"。

re{ n,m}匹配 n 到 m 次由前⾯的正则表达式定义的⽚段,贪婪⽅式a| b匹配a或b(re)匹配括号内的表达式,也表⽰⼀个组(?imx)正则表达式包含三种可选标志:i, m, 或 x 。

只影响括号中的区域。

(?-imx)正则表达式关闭 i, m, 或 x 可选标志。

只影响括号中的区域。

(?: re)类似 (...), 但是不表⽰⼀个组(?imx:re)在括号中使⽤i, m, 或 x 可选标志(?-imx:re)在括号中不使⽤i, m, 或 x 可选标志(?#...)注释.(?= re)前向肯定界定符。

如果所含正则表达式,以 ... 表⽰,在当前位置成功匹配时成功,否则失败。

python常用的正则表达式大全

python常用的正则表达式大全

python常⽤的正则表达式⼤全1.正则表达式正则表达式是⽤来匹配与查找字符串的,从⽹上爬取数据⾃然或多或少会⽤到正则表达式,python的正则表达式要先引⼊re模块,正则表达式以r引导,例如:其中**r“\d+”**正则表达式表⽰匹配连续的多个数值,search是re中的函数,从"abc123cd"字符串中搜索连续的数值,得到"123",返回⼀个匹配对象,结果如上.2.字符串"\d"匹配0~9之间的⼀个数值3.字符"+"重复前⾯⼀个匹配字符⼀次或者多次.注意:**r"b\d+"**第⼀个字符要匹配"b",后⾯是连续的多个数字,因此"是b1233",不是"a12".4.字符"*"重复前⾯⼀个匹配字符零次或者多次.“" 与 "+"类似,但有区别,列如:可见 r"ab+“匹配的是"ab”,但是r"ab “匹配的是"a”,因为表⽰"b"可以重复零次,但是”+“却要求"b"重复⼀次以上.5.字符"?"重复前⾯⼀个匹配字符零次或者⼀次.匹配结果"ab”,重复b⼀次.6.字符".“代表任何⼀个字符,但是没有特别声明时不代表字符”\n".结果“.”代表了字符"x".7."|"代表把左右分成两个部分 .结果匹配"ab"或者"ba"都可以.8.特殊字符使⽤反斜杠"“引导,例如”\r"、"\n"、"\t"、"\"分别表⽰回车、换⾏、制表符号与反斜线⾃⼰本⾝.9.字符"\b"表⽰单词结尾,单词结尾包括各种空⽩字符或者字符串结尾.结果匹配"car",因为"car"后⾯是⼀个空格.10."[]中的字符是任选择⼀个,如果字符ASCll码中连续的⼀组,那么可以使⽤"-"字符连接,例如[0-9]表⽰0-9的其中⼀个数字,[A-Z]表⽰A-Z的其中⼀个⼤写字符,[0-9A-z]表⽰0-9的其中⼀个数字或者A-z的其中⼀个⼤写字符.11."^"出现在[]的第⼀个字符位置,就代表取反,例如[ ^ab0-9]表⽰不是a、b,也不是0-9的数字.12."\s"匹配任何空⽩字符,等价"[\r\n 20\t\f\v]"13."\w"匹配包括下划线⼦内的单词字符,等价于"[a-zA-Z0-9]"14."$"字符⽐配字符串的结尾位置匹配结果是最后⼀个"ab",⽽不是第⼀个"ab"15.使⽤括号(…)可以把(…)看出⼀个整体,经常与"+"、"*"、"?"的连续使⽤,对(…)部分进⾏重复.结果匹配"abab","+“对"ab"进⾏了重复16.查找匹配字符串正则表达式re库的search函数使⽤正则表达式对要匹配的字符串进⾏匹配,如果匹配不成功返回None,如果匹配成功返回⼀个匹配对象,匹配对象调⽤start()函数得到匹配字符的开始位置,匹配对象调⽤end()函数得到匹配字符串的结束位置,search虽然只返回匹配第⼀次匹配的结果,但是我们只要连续使⽤search函数就可以找到字符串全部匹配的字符串.匹配找出英⽂句⼦中所有单词我们可以使⽤正则表达式r”[A-Za-z]+\b"匹配单词,它表⽰匹配由⼤⼩写字母组成的连续多个字符,⼀般是⼀个单词,之后"\b"表⽰单词结尾.程序开始匹配到⼀个单词后m.start(),m.end()就是单词的起始位置,s[start:end]为截取的单词,之后程序再次匹配字符串s=s[end:],即字符串的后半段,⼀直到匹配完毕为⽌就找出每个单词.总结到此这篇关于python常⽤正则表达式的⽂章就介绍到这了,更多相关python正则表达式内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!。

python正则表达式详解

python正则表达式详解

python正则表达式详解Python正则表达式详解正则表达式是一种强大的文本处理工具,它可以用来匹配、查找、替换文本中的特定模式。

在Python中,正则表达式是通过re模块来实现的。

本文将详细介绍Python中正则表达式的使用方法。

一、基本语法正则表达式是由一些特殊字符和普通字符组成的字符串。

其中,特殊字符用来表示一些特定的模式,普通字符则表示普通的文本。

下面是一些常用的正则表达式特殊字符:1. ^:匹配字符串的开头。

2. $:匹配字符串的结尾。

3. .:匹配任意一个字符。

4. *:匹配前面的字符出现0次或多次。

5. +:匹配前面的字符出现1次或多次。

6. ?:匹配前面的字符出现0次或1次。

7. []:匹配方括号中的任意一个字符。

8. [^]:匹配不在方括号中的任意一个字符。

9. ():将括号中的内容作为一个整体进行匹配。

10. |:匹配左右两边任意一个表达式。

二、常用函数Python中re模块提供了一些常用的函数来操作正则表达式,下面是一些常用的函数:1. re.match(pattern, string, flags=0):从字符串的开头开始匹配,如果匹配成功则返回一个匹配对象,否则返回None。

2. re.search(pattern, string, flags=0):在字符串中查找第一个匹配成功的子串,如果匹配成功则返回一个匹配对象,否则返回None。

3. re.findall(pattern, string, flags=0):在字符串中查找所有匹配成功的子串,返回一个列表。

4. re.sub(pattern, repl, string, count=0, flags=0):将字符串中所有匹配成功的子串替换为repl,返回替换后的字符串。

三、实例演示下面是一些实例演示,展示了正则表达式的使用方法:1. 匹配邮箱地址import reemail='*************'pattern = r'\w+@\w+\.\w+' result = re.match(pattern, email) if result:print(result.group())else:print('匹配失败')2. 匹配手机号码import rephone='138****5678' pattern = r'^1[3-9]\d{9}$' result = re.match(pattern, phone) if result:print(result.group())else:print('匹配失败')3. 查找所有数字import retext = 'abc123def456ghi789' pattern = r'\d+'result = re.findall(pattern, text)print(result)4. 替换字符串中的空格import retext = 'hello world'pattern = r'\s+'result = re.sub(pattern, '-', text)print(result)四、总结本文介绍了Python中正则表达式的基本语法和常用函数,并通过实例演示展示了正则表达式的使用方法。

python正则表达式匹配加减乘除运算

python正则表达式匹配加减乘除运算

在Python编程中,正则表达式是一种强大的工具,可以用来匹配字符串中的特定模式。

而加减乘除运算则是数学中基本的四则运算,是我们在日常生活中经常会用到的计算方法。

本篇文章将从简到繁地探讨如何利用Python中的正则表达式来进行加减乘除运算,以帮助读者更深入地理解这一主题。

1. 正则表达式简介让我们简要回顾一下正则表达式的基本知识。

正则表达式是用来描述字符序列的一种方法,可以用来匹配、查找和替换字符串中的特定模式。

在Python中,我们可以使用re模块来操作正则表达式,实现对字符串的模式匹配和提取。

2. 匹配加减乘除运算现在,让我们开始探讨如何利用正则表达式来匹配加减乘除运算。

假设我们有一个包含加减乘除运算的字符串,我们希望能够用正则表达式来提取出运算符和操作数,以便进行计算。

这就需要我们编写一个合适的正则表达式模式,来匹配这些运算符和操作数。

3. 编写正则表达式模式对于加减乘除运算,我们可以将正则表达式模式设计为匹配两个操作数和一个运算符的形式。

我们可以使用如下的正则表达式模式来匹配加法运算:```(\d+)[\s]*\+[\s]*(\d+)```这个正则表达式模式中,`(\d+)`匹配一个或多个数字作为操作数,`[\s]*`匹配零个或多个空格,`\+`匹配加号运算符。

通过类似的方式,我们还可以设计模式来匹配减法、乘法和除法运算。

4. 使用正则表达式进行运算一旦我们设计好了匹配加减乘除运算的正则表达式模式,就可以利用Python中re模块提供的函数来进行匹配和提取操作。

我们可以使用re.match和re.search函数来寻找字符串中匹配的模式,并提取出操作数和运算符,然后进行相应的运算。

5. 个人观点和理解通过使用正则表达式进行加减乘除运算,我们可以实现对包含运算式的字符串进行自动化的计算,极大地提高了程序的灵活性和效率。

正则表达式的灵活性和强大功能也为我们提供了更多处理字符串的方法。

总结通过本文的讨论,我们了解了如何利用Python中的正则表达式来进行加减乘除运算。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
python 的正则表达式 re
延伸阅读:python 的 内建函数 和 subprocess 。此文是本系列的第三篇文章了,和 之前一样,内容出自官方文档,但是会有自己的理,并非单纯的翻译。所以,如果我理解 有误,欢迎指正,谢谢。
本模块提供了和 Perl 里的正则表达式类似的功能,不关是正则表达式本身还是被搜索 的字符串,都可以是 Unicode 字符,这点不用担心,python 会处理地和 Ascii 字符一样漂 亮。
'.'
点号,在普通模式,它匹配除换行符外的任意一个字符;如果指定了 DOTALL 标记, 匹配包括换行符以内的任意一个字符。
'^'
尖尖号,匹配一个字符串的开始,在 MULTILINE 模式下,也将匹配任意一个新行的 开始。
'$'
美元符号,匹配一个字符串的结尾或者字符串最后面的换行符,在 MULTILINE 模式 下,也匹配任意一行的行尾。也就是说,普通模式下,foo.$去搜索'foo1\nfoo2\n'只会找 到’foo2′,但是在 MULTILINE 模式,还能找到 ‘foo1′,而且就用一个 $ 去搜索'foo\n' 的话,会找到两个空的匹配:一个是最后的换行符,一个是字符串的结尾,演示:
注意:在中括号里,+、*、(、)这类字符将会失去特殊含义,仅作为普通字符。反向引 用也不能在中括号内使用。
'|' 管道符号,A 和 B 是任意的 RE,那么 A|B 就是匹配 A 或者 B 的一个新的 RE。任意个 数的 RE 都可以像这样用管道符号间隔连接起来。这种形式可以被用于组中(后面将详 述)。对于目标字符串,被'|'分割的 RE 将自左至右一一被测试,一旦有一个测试成功,后 面的将不再被测试,即使后面的 RE 可能可以匹配更长的串,换句话说,'|'操作符是非贪婪 的。要匹配字面意义上的'|',可以用反斜杆转义:\|,或是包含在反括号内:[|]。 (...) 匹配圆括号里的 RE 匹配的内容,并指定组的开始和结束位置。组里面的内容可以被提 取,也可以采用\number 这样的特殊序列,被用于后续的匹配。要匹配字面意义上的'('和 ')',可以用反斜杆转义:\(、\),或是包含在反括号内:[(]、[)]。 (?...) 这是一个表达式的扩展符号。'?'后的第一个字母决定了整个表达式的语法和含义,除了 (?P...)以外,表达式不会产生一个新的组。下面介绍几个目前已被支持的扩展: (?iLmsux) 'i'、'L'、'm'、's'、'u'、'x'里的一个或多个字母。表达式不匹配任何字符,但是指定相 应的标志:re.I(忽略大小写)、re.L(依赖 locale)、re.M(多行模式)、re.S(.匹配所有字符)、 re.U(依赖 Unicode)、re.X(详细模式)。关于各个模式的区别,下面会有专门的一节来介绍 的。使用这个语法可以代替在 pile()的时候或者调用的时候指定 flag 参数。 例如,上面举过的例子,可以改写成这样(和指定了 re.MULTILINE 是一样的效果): >>> re.findall('(?m)(foo.$)', 'foo1\nfoo2\n') ['foo1', 'foo2'] 另外,还要注意(?x)标志如果有的话,要放在最前面。 (?:...) 匹配内部的 RE 所匹配的内容,但是不建立组。 (?P<name>...) 和普通的圆括号类似,但是子串匹配到的内容将可以用命名的 name 参数来提取。组的 name 必须是有效的 python 标识符,而且在本表达式内不重名。命名了的组和普通组一 样,也用数字来提取,也就是说名字只是个额外的属性。 演示一下: >>> m=re.match('(?P<var>[a-zA-Z_]\w*)', 'abc=123')
你也可以在字符串前加上 r 这个前缀来避免部分疑惑,因为 r 开头的 python 字符串是 raw 字符串,所以里面的所有字符都不会被转义,比如 r'\n'这个字符串就是一个反斜杆加 上一字母 n,而'\n'我们知道这是个换行符。因此,上面的'\\\\'你也可以写成 r'\\',这样, 应该就好理解很多了。可以看下面这段:
正则表达式使用反斜杆(\)来转义特殊字符,使其可以匹配字符本身,而不是指定其 他特殊的含义。这可能会和 python 字面意义上的字符串转义相冲突,这也许有些令人费 解。比如,要匹配一个反斜杆本身,你也许要用'\\\\'来做为正则表达式的字符串,因为正 则表达式要是\\,而字符串里,每个反斜杆都要写成\\。
如有由 id 或者 name 指定的组存在的话,将会匹配 yes-pattern,否则将会匹配 nopattern,通常情况下 no-pattern 也可以省略。例如:()可以匹配 '<user@>' 和 'user@',但是不会匹配 '<user@'。
>>> import re >>> s = '\x5c' #0x5c 就是反斜杆 >>> print s \ >>> re.match('\\\\', s) #这样可以匹配 <_sre.SRE_Match object at 0xb6949e20> >>> re.match(r'\\', s) #这样也可以 <_sre.SRE_Match object at 0x80ce2c0> >>> re.match('\\', s) #但是这样不行 Traceback (most recent call last):
>>> m.group('var') 'abc' >>> m.group(1) 'abc' (?P=name) 匹配之前以 name 命名的组里的内容。 演示一下: >>> re.match('<(?P<tagname>\w*)>.*</(?P=tagname)>', '<h1>xxx</h2>') # 这个不匹配 >>> re.match('<(?P<tagname>\w*)>.*</(?P=tagname)>', '<h1>xxx</h1>') # 这个匹配 <_sre.SRE_Match object at 0xb69588e0> (?#...) 注释,圆括号里的内容会被忽略。 (?=...) 如果 ... 匹配接下来的字符,才算匹配,但是并不会消耗任何被匹配的字符。例如 Isaac (?=Asimov) 只会匹配后面跟着 'Asimov' 的 'Isaac ',这个叫做“前瞻断言”。 (?!...) 和上面的相反,只匹配接下来的字符串不匹配 ... 的串,这叫做“反前瞻断言”。 (?<=...) 只有当当前位置之前的字符串匹配 ... ,整个匹配才有效,这叫“后顾断言”。 (?<=abc)def 会找到 'abcdef',因为会后向查找 3 个字符,看是否为 abc。所以内置的子 RE,需要是固定长度的,比如可以是 abc、a|b,但不能是 a*、a{3,4}。注意这种 RE 永远 不会匹配到字符串的开头。举个例子,找到连字符('-')后的单词: >>> m = re.search('(?<=-)\w+', 'spam-egg') >>> m.group(0) 'egg' (?<!...) 同理,这个叫做“反后顾断言”,子 RE 需要固定长度的,含义是前面的字符串不匹 配 ... 整个才算匹配。 (?(id/name)yes-pattern|no-pattern)
>>> re.findall('(foo.$)', 'foo1\nfoo2\n') ['foo2'] >>> re.findall('(foo.$)', 'foo1\nfoo2\n', re.MULTILINE) ['foo1', 'foo2'] >>> re.findall('($)', 'foo\n') ['', '']
正则表达式可以包含特殊字符和普通字符,大部分字符比如'A','a'和'0'都是普通字 符,如果做为正则表达式,它们将匹配它们本身。由于正则表达式可以连接,所以连接多个 普通字符而成的正则表达式 last 也将匹配'last'。(后面将用不带引号的表示正则表达式, 带引号的表示字符串)
下面就来介绍正则表达式的特殊字符:
正则表达式语法
正则表达式(RE)指定一个与之匹配的字符集合;本模块所提供的函数,将可以用来 检查所给的字符串是否与指定的正则表达式匹配。
正则表达式可以被连接,从而形成新的正则表达式;例如 A 和 B 都是正则表达式,那 么 AB 也是正则表达式。一般地,如果字符串 p 与 A 匹配,q 与 B 匹配的话,那么字符串 pq 也会与 AB 匹配,但 A 或者 B 里含有边界限定条件或者命名组操作的情况除外。也就是 说,复杂的正则表达式可以用简单的连接而成。
相关文档
最新文档