Python-正则对象的方法

re 模块使Python 语言拥有全部的正则表达式功能

complile函数根据一个模式字符串和可选的标志函数生成一个正则表达式对象。该对象拥有一系列方法用于正则表达式匹配和替换。

1.match 方法

rematch 尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成的话,match() 返回None

匹配成果返回一个匹配的对象。

语法:

match(string[, pos[, endpos]])

string:匹配使用的文本,

pos: 文本中正则表达式开始搜索的索引。及开始搜索string的下标

endpos: 文本中正则表达式结束搜索的索引。

如果不指定pos,默认是从开头开始匹配,如果匹配不到,直接返回None

匹配对象方法描述group(num=0)匹配的整个表达式的字符串,group() 可以一次输入多个组号,在这种情况下它将返回一个包含那些组所对应值的元组。groups()返回一个包含所有小组字符串的元组,从 1 到 所含的小组号。

使用group()、groups()匹配对象函数来获取匹配表达式.

import re
print(re.match('www','www.runoob.com').span())
print(re.match('com','www.runoob.com'))
(0, 3)
None
result = pattern.match(r'aahello world hello ling')
print(result)
result2 = pattern.match(r'hello world hello ling')
print(result2.groups())
<_sre.SRE_Match object at 0x00000000025450B8>
('hello world ', 'hello ling')
解释:如果不指定pos的话,默认是从字符串开始位置匹配,匹配不到就返回None,以上所有的pattern都是一个match对象,


2. search 方法

search(string[, pos[, endpos]])

这个方法用于查找字符串中可以匹配成功的子串。从string的pos下标处起尝试匹配pattern,如果pattern结束时仍可匹配,则返回一个Match对象;若无法匹配,则将pos加1后重新尝试匹配;直到pos=endpos时仍无法匹配则返回None。

import re
pattern = re.compile(r'(hello w.*)(hello l.*)')
result1 = pattern.search(r'aahello world hello ling')
print(result1.groups())
('hello world ', 'hello ling')

match  ()方法默认从开始匹配,若匹配不到直接返回none。

search()方法 从开始位置匹配,若匹配不到,下标加一,直到最后。


3. split 方法

split(string[, maxsplit])

按照能够匹配的子串将string分割后返回列表。maxsplit用于指定最大分割次数,不指定将全部分割
import re
p = re.compile(r'\d+')
print(p.split('one1two2three3four4'))

['one', 'two', 'three', 'four', '']

解释:直接把p的正则当成是分隔符,然后把最后的字符串用p进行分割,然后返回回去



4.findall 方法

findall(string[, pos[, endpos]]) 

搜索string,以列表形式返回全部能匹配的子串.

import re
p = re.compile(r'\d+')
print(p.findall('one1two2three3four4'))

['1', '2', '3', '4']

结果:findall是把匹配到的字符串最后一列表的形式返回回去


5 .finditer 方法

finditer(string[, pos[, endpos]])

搜索string,返回一个顺序访问每一个匹配结果(Match对象)的迭代器
import re
p = re.compile(r'\d+')
print(type(p.finditer('one1two2three3four4')))
for m in p.finditer('one1two2three3four4'):
    print(type(m))
print(m.group())

<type 'callable-iterator'>
<type '_sre.SRE_Match'>
<type '_sre.SRE_Match'>
<type '_sre.SRE_Match'>
<type '_sre.SRE_Match'>
4

解释:

p.finditer('one1two2three3four4')是一个迭代器,而返回的每个m都是match对象

6. match匹配对象

Match对象是一次匹配的结果,包含了很多关于此次匹配的信息,可以使用Match提供的可读属性或方法来获取这些信息。上面的过程中多次使用了match对象,调用了他的group()和groups()等方法。

import re
prog = re.compile(r'(?P<tagname>abc)(.*)(?P=tagname)')
result1 = prog.match('abclfjlad234sjldabc')
print(result1)
print(result1.groups())
print result1.group('tagname')
print(result1.group(2))
print(result1.groupdict())

<_sre.SRE_Match object at 0x0000000002585140>
('abc', 'lfjlad234sjld')
abc
lfjlad234sjld
{'tagname': 'abc'}

解释:

1,我们可以看到result1已经由字符串转换成了一个正则对象。

2,resule.groups()可以查看出来所有匹配到的数据,每个()是一个元素,最终返回一个tuple

3,group()既可以通过下标(从1开始)的方式访问,也可以通过分组名进行访问。

4,groupdict只能显示有分组名的数据


group([group1, …]): 
获得一个或多个分组截获的字符串;指定多个参数时将以元组形式返回。group1可以使用编号也可以使用别名;编号0代表整个匹配的子串;不填写参数时,返回group(0);没有截获字符串的组返回None;截获了多次的组返回最后一次截获的子串。

groups([default]): 
以元组形式返回全部分组截获的字符串。相当于调用group(1,2,…last)。default表示没有截获字符串的组以这个值替代,默认为None。

groupdict([default]): 
返回以有别名的组的别名为键、以该组截获的子串为值的字典,没有别名的组不包含在内。default含义同上。
















评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值