Python提供了基于正则表达式的两种不同的原始操作:
-
re.match()
仅在字符串的开头检查匹配,只有在0位置匹配成功的话才有返回,如果不是开始位置匹配成功的话,match()就返回none。 -
re.search()
检查字符串中任何位置的匹配
例如:
In [2]: re.match("c","absdbdfskdvc")
In [3]: re.search("c","absdbdfskdvc")
Out[3]: <_sre.SRE_Match object; span=(11, 12), match='c'>
以'^'
开头的正则表达式可以与search()
一起使用,以限制字符串开始处的匹配:
>>> re.match("c", "abcdef") # No match
>>> re.search("^c", "abcdef") # No match
>>> re.search("^a", "abcdef") # Match
<_sre.SRE_Match object; span=(0, 1), match='a'>
re.search(pattern,string,flags = 0)
扫描通过字符串查找正则表达式模式产生匹配的第一个位置,并返回相应的匹配对象。 返回None,如果字符串中没有位置匹配模式; 请注意,这不同于在字符串中的某一点找到零长度匹配。
In [7]: re.search("c","absdbdfskdvc").span()
Out[7]: (11, 12)
re.match(pattern,string,flags = 0)
如果字符串开头的零个或多个字符与正则表达式模式匹配,则返回相应的匹配对象。 如果字符串与模式不匹配,返回None; 请注意,这与零长度匹配不同。
In [8]: re.match("c","ccccabsdbdfskdvc").span()
Out[8]: (0, 1)