Chinaunix首页 | 论坛 | 博客
  • 博客访问: 361731
  • 博文数量: 150
  • 博客积分: 3423
  • 博客等级: 中校
  • 技术积分: 1005
  • 用 户 组: 普通用户
  • 注册时间: 2011-07-15 09:04
文章分类

全部博文(150)

文章存档

2012年(2)

2011年(148)

分类: Python/Ruby

2011-09-09 14:58:09

一些regular的tips:

非贪婪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+?)b""a23b")
        
['23']

如果你要多行匹配,那么加上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']

可见,是无需re.M

阅读(905) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~