结果:
11/27/2018
11
27
2018
('11', '27', '2018')
11
27
2018
********************
2018-11-27
2018-11-26
********************
('11', '27', '2018')
('11', '26', '2018')
3、分析
本节主要介绍了re模块对文本匹配和搜索的基本功能,首先用re.compile()对模式进行编译,然后使用想match()、findall()、finditer()这样的方法做匹配和搜索。
当指定模式时我们通常会使用原始字符串,例如:
r'(d+)/(d+)/(d+)'
这样的字符串不会对反斜字符转义,这在正则表达式中非常有用。否则,我们需要用双反斜杠线来标识一个单独的'',例如:
'(d+)/(d+)/(d+)'
请注意match()方法只会检查字符的开头,有可能出现的匹配的结果并不是你想要的,例如:
import re
#加入捕获组
datepat=re.compile(r'(d+)+/(d+)+/(d+)')
m=datepat.match('11/27/2018xxxx')
print(m)
结果:
<re.Match object; span=(0, 10), match='11/27/2018'>
如果想要精确匹配,可以加一个结束标记:$
import re
#加入捕获组
datepat=re.compile(r'(d+)+/(d+)+/(d+)$')
m1=datepat.match('11/27/2018xxxx')
m2=datepat.match('11/27/2018')
print(m1)
print(m2)
结果:
None
<re.Match object; span=(0, 10), match='11/27/2018'>
如果只是执行简单的文本匹配和搜索操作,可以省略编译步骤。
如果打算执行很多匹配或查找操作的话,通常需要先将模式编译然后重复使用。模块级的函数会对最近编译过的模式做缓存处理,并且比较省步骤。
总结
以上所述是小编给大家介绍的正则表达式之文本模式的匹配和查找,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对易采站长站网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!









