1 非贪婪flag

> re.findall(r"a(\d+", "a23b")
  ['2']
> re.findall(r"a(\d+)", "a23b")
  ['23']

注意比较这种情况:

> re.findall(r"a(\d+)b", "a23b")
  ['23']
> re.findall(r"a(\d+", "a23b")
  ['23']

2 如果你要多行匹配,那么加上re.S和re.M标志

re.S:.将会匹配换行符,默认.不会匹配换行符

> re.findall(r"a(\d+)b.+a(\d+)b", "a23b\na34b")
  []
> re.findall(r"a(\d+)b.+a(\d+)b", "a23b\na34b", re.S)
  [('23', '34')]
>

re.M:^$标志将会匹配每一行,默认^和$只会匹配第一行

> re.findall(r"^a(\d+)b", "a23b\na34b")
  ['23']
> re.findall(r"^a(\d+)b", "a23b\na34b", re.M)
  ['23', '34']

但是,如果没有^标志,

> re.findall(r"a(\d+)b", "a23b\na23b")
  ['23', '23']

以上这篇python贪婪匹配以及多行匹配的实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com