有关 ECMAScript 2020 新特性的全面解析
887
2022-09-16
Python正则表达式如何正确运用?七大案例详解
作为一个概念而言,正则表达式对于Python来说并不是独有的。但是,Python中的正则表达式在实际使用过程中还是有一些细小的差别。
本文是一系列关于Python正则表达式文章的其中一部分。在这个系列的第一篇文章中,我们将重点讨论如何使用Python中的正则表达式并突出Python中一些独有的特性。
我们将介绍Python中对字符串进行搜索和查找的一些方法。然后我们讲讨论如何使用分组来处理我们查找到的匹配对象的子项。
另外注意:光理论是不够的。这里顺便免费送大家一套2020最新python入门到高级项目实战视频教程,可以去小编的Python交流.裙 :七衣衣九七七巴而五(数字的谐音)转换下可以找到了,还可以跟老司机交流讨教!
我们有兴趣使用的Python中正则表达式的模块通常叫做‘re'。
1
>>> import re
1. Python中的原始类型字符串
Python编译器用‘'(反斜杠)来表示字符串常量中的转义字符。
如果反斜杠后面跟着一串编译器能够识别的特殊字符,那么整个转义序列将被替换成对应的特殊字符(例如,‘ '将被编译器替换成换行符)。
但这给在Python中使用正则表达式带来了一个问题,因为在‘re'模块中也使用反斜杠来转义正则表达式中的特殊字符(比如*和+)。
这两种方式的混合意味着有时候你不得不转义转义字符本身(当特殊字符能同时被Python和正则表达式的编译器识别的时候),但在其他时候你不必这么做(如果特殊字符只能被Python编译器识别)。
与其将我们的心思放在去弄懂到底需要多少个反斜杠,我们可以使用原始字符串来替代。
原始类型字符串可以简单的通过在普通字符串的双引号前面加一个字符‘r'来创建。当一个字符串是原始类型时,Python编译器不会对其尝试做任何的替换。本质上来讲,你在告诉编译器完全不要去干涉你的字符串。
1
2
3
4
5
>>> string = 'This is a
normal string'
>>> rawString = r'and this is a
raw string'
>>> print string
这是一个普通字符串
1
2
3
>>> print rawString
and this is a
raw string
这是一个原始类型字符串。
在Python中使用正则表达式进行查找
‘re'模块提供了几个方法对输入的字符串进行确切的查询。我们将会要讨论的方法有:
1
2
3
•re.match()
•re.search()
•re.findall()
每一个方法都接收一个正则表达式和一个待查找匹配的字符串。让我们更详细的查看这每一个方法从而弄明白他们是如何工作的以及他们各有什么不同。
2. 使用re.match查找 – 匹配开始
让我们先来看一下match()方法。match()方法的工作方式是只有当被搜索字符串的开头匹配模式的时候它才能查找到匹配对象。
举个例子,对字符串‘dog cat dog'调用mathch()方法,查找模式‘dog'将会匹配:
1
2
3
4
5
>>> re.match(r'dog', 'dog cat dog')
<_sre.sre_match>
>>> match = re.match(r'dog', 'dog cat dog')
>>> match.group(0)
'dog'
我们稍后将更多的讨论group()方法。现在,我们只需要知道我们用0作为它的参数调用了它,group()方法返回查找到的匹配的模式。
我还暂且略过了返回的SRE_Match对象,我们很快也将会讨论到它。
但是,如果我们对同一个字符串调用math()方法,查找模式‘cat',则不会找到匹配。
1
2
>>> re.match(r'cat', 'dog cat dog')
>>>
3. 使用re.search查找 – 匹配任意位置
search()方法和match()类似,不过search()方法不会限制我们只从字符串的开头查找匹配,因此在我们的示例字符串中查找‘cat'会查找到一个匹配:
1
2
3
search(r'cat', 'dog cat dog')
>>> match.group(0)
'cat'
然而search()方法会在它查找到一个匹配项之后停止继续查找,因此在我们的示例字符串中用searc()方法查找‘dog'只找到其首次出现的位置。
1
2
3
>>> match = re.search(r'dog', 'dog cat dog')
>>> match.group(0)
'dog
共3页: 上一页123下一页
>>> match = re.match(r'dog', 'dog cat dog')
>>> match.group(0)
'dog'
我们稍后将更多的讨论group()方法。现在,我们只需要知道我们用0作为它的参数调用了它,group()方法返回查找到的匹配的模式。
我还暂且略过了返回的SRE_Match对象,我们很快也将会讨论到它。
但是,如果我们对同一个字符串调用math()方法,查找模式‘cat',则不会找到匹配。
1
2
>>> re.match(r'cat', 'dog cat dog')
>>>
3. 使用re.search查找 – 匹配任意位置
search()方法和match()类似,不过search()方法不会限制我们只从字符串的开头查找匹配,因此在我们的示例字符串中查找‘cat'会查找到一个匹配:
1
2
3
search(r'cat', 'dog cat dog')
>>> match.group(0)
'cat'
然而search()方法会在它查找到一个匹配项之后停止继续查找,因此在我们的示例字符串中用searc()方法查找‘dog'只找到其首次出现的位置。
1
2
3
>>> match = re.search(r'dog', 'dog cat dog')
>>> match.group(0)
'dog
共3页: 上一页123下一页
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~