最新消息:最新信息可以到系统基本设置里填写,如果不想要这一栏可以修改head.htm,将第53行到55行删除即可

Python正则表达式的7个使用典范(推荐)

创意新鲜 dedesos.com

作为一个概念而言,正则表达式对于python来说并不是独有的。但是,python中的正则表达式在实际使用过程中还是有一些细小的差别。

将介绍python中对字符串进行搜索和查找的一些方法,讨论如何使用分组来处理我们查找到的匹配对象的子项。

使用的python中正则表达式的模块通常叫做‘re'。

import re

1.python中的原始类型字符串

python编译器用‘'来表示字符串常量中的转义字符。

如果反斜杠后面跟着一串编译器能够识别的特殊字符,那么整个转义序列将被替换成对应的特殊字符。

但这给在python中使用正则表达式带来了一个问题,因为在‘re'模块中也使用反斜杠来转义正则表达式中的特殊字符。

这两种方式的混合意味着有时候你不得不转义转义字符本身,但在其他时候你不必这么做。

与其将我们的心思放在去弄懂到底需要多少个反斜杠,我们可以使用原始字符串来替代。

原始类型字符串可以简单的通过在普通字符串的双引号前面加一个字符‘r'来创建。当一个字符串是原始类型时,python编译器不会对其尝试做任何的替换。本质上来讲,你在告诉编译器完全不要去干涉你的字符串。

 string = 'this is a
normal string'
 rawstring = r'and this is a
raw string'
 print string

这是一个普通字符串

 print rawstring
and this is a
raw string

这是一个原始类型字符串。

在python中使用正则表达式进行查找


re.match
re.search
re.findall



每一个方法都接收一个正则表达式和一个待查找匹配的字符串。让我们更详细的查看这每一个方法从而弄明白他们是如何工作的以及他们各有什么不同。

2.使用re.match查找 – 匹配开始

让我们先来看一下match方法。match方法的工作方式是只有当被搜索字符串的开头匹配模式的时候它才能查找到匹配对象。


 re.match
 _sre.sre_match object at 0xb743e720 
 match = re.match
 match.group
'dog'

我们稍后将更多的讨论group方法。现在,我们只需要知道我们用0作为它的参数调用了它,group方法返回查找到的匹配的模式。

我还暂且略过了返回的sre_match对象,我们很快也将会讨论到它。


 re.match
 

3.使用re.search查找 – 匹配任意位置


search
 match.group
'cat'

 match = re.search
 match.group
'dog'

4.使用 re.findall – 所有匹配对象


['dog', 'dog']
 re.findall
['cat']

5.使用 match.start 和 match.end 方法

那么,先前search和match方法先前返回给我们的‘match'对象”到底是什么呢?

和只简单的返回字符串的匹配部分不同,search和match返回的“匹配对象”,实际上是一个关于匹配子串的包装类。

先前你看到我可以通过调用group方法得到匹配的子串,,但是匹配对象还包含了更多关于匹配子串的信息。


 match = re.search
 match.start
 match.end

知道这些信息有时候非常有用。

6.使用 mathch.group 通过数字分组

就像我之前提到的,匹配对象在处理分组时非常得心应手。

分组是对整个正则表达式的特定子串进行定位的能力。我们可以定义一个分组做为整个正则表达式的一部分,然后单独的对这部分对应匹配到的内容定位。

让我们来看一下它是怎么工作的:

contactinfo = 'doe, john: 555-1212'

我刚才创建的字符串类似一个从某人的地址本里取出来的一个片段。我们可以通过这样一个正则表达式来匹配这一行:

 re.search
 _sre.sre_match object at 0xb74e1ad8 

通过用圆括号来包围正则表达式的特定部分,我们可以对内容进行分组然后对这些子组做单独处理。

 match = re.search, : ', contactinfo)

这些分组可以通过用分组对象的group方法得到。它们可以通过其在正则表达式中从左到右出现的数字顺序来定位:

 match.group
'doe'
 match.group
'john'
 match.group
'555-1212'

 match.group
'doe, john: 555-1212'

7.使用 match.group 通过别名来分组

有时候,特别是当一个正则表达式有很多分组的时候,通过组的出现次序来定位就会变的不现实。python还允许你通过下面的语句来指定一个组名:

 match = re.search, : ', contactinfo)

我们还是可以用group方法获取分组的内容,但这时候我们要用我们所指定的组名而不是之前所使用的组的所在位数。

 match.group
'doe'
 match.group
'john'
 match.group
'555-1212'

但是,给分组命名并不适用于findall方法。

在本文中我们介绍了python中使用正则表达式的一些基础,学习了原始字符串类型。还学习了如何适使用match, search, and findall方法进行基本的查询,以及如何使用分组来处理匹配对象的子组件。

和往常一样,如果想查看更多关于这个主题的内容,re模块的python官方文档是一个非常好的资源。

总结

    网友最新评论