search()方法既有模块级别的,即re.search();编译后的正则表达式对象也同样拥有search() 方法。
但是两者还是有些细微差别的:
re.search() 有个参数flags是表示编译标志。而regex.search() 有两个参数pos和endpos用来表示搜索的起始位置和终止位置。
search()方法并不会立刻返回我们能够使用的字符串,返回的而是一个匹配对象。
>>> import re
>>> result = re.search(r' (\w+) (\w+)', 'I Love Study!') #\w表示匹配任何字符单词,+表示匹配一次或多次
>>> result #可以看出result是一个正则表达式匹配对象
<_sre.SRE_Match object; span=(1, 12), match=' Love Study'>
>>> result.group()#使用一些方法才能获得我们需要的字符串,例如group()方法
' Love Study'
#对于group()方法,如果正则表达式模式中存在子组,那么子组会将匹配的内容进行捕获,通过对group()方法设置序号,可以提取对应子组捕获的字符串
>>> result.group(1) #提取第一个子组捕获的内容
'Love'
>>> result.group(2) #提取第二个子组捕获的内容
'Study'
#返回的对象还有几个方法:start()表示匹配开始的位置, end()表示匹配结束的位置, span()表示匹配的范围
>>> result.start()
1
>&