你想在如何在字符串中搜索和匹配指定的文本模式

对于简单的字面模式,直接使用str.replace()方法即可,比如:>>> text=’yeah, but no, but yeah, but no, but yeah’>>> text.replace(‘yeah’,’yep’)

‘yep, but no, but yep, but no, but yep’>>>

对于复杂的模式,请使用re模块中的sub()函数。为了说明这个,假设你想将形式为11/27/2012的日期字符串改成2012-11-27。示例如下:>>> text=’Today is 11/27/2012. PyCon starts 3/13/2013.’>>> import re

>>> re.sub(r'(\d+)/(\d+)/(\d+)’, r’\3-\1-\2′, text)’Today is 2012-11-27. PyCon starts 2013-3-13.’

>>>

sub()函数中的第一个参数是被匹配的模式,第二个参数是替换模式。反斜杠数字比如\3指向前面模式的捕获组号。

如果你打算用相同的模式做多次替换,考虑先编译它来提升性能。比如:>>> import re

>>> datepat= re.compile(r'(\d+)/(\d+)/(\d+)’)>>> datepat.sub(r’\3-\1-\2′, text)

‘Today is 2012-11-27. PyCon starts 2013-3-13.’>>>

对于更加复杂的替换,可以传递一个替换回调函数来代替,比如:>>> from calendar import month_abbr>>> def change_date(m):

… mon_name= month_abbr[int(m.group(1))]

… return'{}{}{}’.format(m.group(2), mon_name, m.group(3))…

>>> datepat.sub(change_date, text)

‘Today is 27 Nov 2012. PyCon starts 13 Mar 2013.’>>>

一个替换回调函数的参数是一个match对象,也就是match()或者find()返回的对象。使用group()方法来提取特定的匹配部分。回调函数最后返回替换字符串。

如果除了替换后的结果外,你还想知道有多少替换发生了,可以使用re.subn()来代替。比如:

>>> newtext, n= datepat.subn(r’\3-\1-\2′, text)>>> newtext

‘Today is 2012-11-27. PyCon starts 2013-3-13.’>>> n

 

赞(0)
未经允许不得转载:千千惠生活达人注册 » 你想在如何在字符串中搜索和匹配指定的文本模式