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)