re.match()从开头开始匹配string。
re.search()从anywhere 来匹配string。
例子:
>>> re.match("c", "abcdef") # No match
>>> re.search("c", "abcdef") # Match
<_sre.SRE_Match object at ...>
可以加个’^’来强制search从开头开始匹配。
>>> re.match("c", "abcdef") # No match
>>> re.search("^c", "abcdef") # No match
>>> re.search("^a", "abcdef") # Match
<_sre.SRE_Match object at ...>
MULTILINE 多行模式下,match也只匹配string的开头部分,而用了’^’正则的re.search()可以匹配多行。
>>> re.match('X', 'A\nB\nX', re.MULTILINE) # No match
>>> re.search('^X', 'A\nB\nX', re.MULTILINE) # Match
<_sre.SRE_Match object at ...>
re.match() ,re.search()都返回re.MatchObject ,他常用的方法就是group() ,groups(),span()
另外在补充一个search的基本用法:
for process in res:
# print process
if re.search('java', process):
print process