- 論壇徽章:
- 0
|
一些regular的tips:
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+?)b", "a23b")
['23']
2 如果你要多行匹配,那么加上re.S和re.M標(biāo)志
re.S:.將會(huì)匹配換行符,默認(rèn).不會(huì)匹配換行符
>>> 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:^$標(biāo)志將會(huì)匹配每一行,默認(rèn)^和$只會(huì)匹配第一行
>>> re.findall(r"^a(\d+)b", "a23b\na34b")
['23']
>>> re.findall(r"^a(\d+)b", "a23b\na34b", re.M)
['23', '34']
但是,如果沒有^標(biāo)志,
>>> re.findall(r"a(\d+)b", "a23b\na23b")
['23', '23']
可見,是無(wú)需re.M
本文來(lái)自ChinaUnix博客,如果查看原文請(qǐng)點(diǎn):http://blog.chinaunix.net/u2/60589/showart_2091807.html |
|