re.match和re.search简介
re.match函数
语法:
re.search(pattern,string,flags=0)
re.match 尝试从字符串的起始位置匹配一个模式,如果不是起始位置匹配成功的话,match() 就返回 none。
re.search函数
语法:
re.search(pattern, string, flags=0)
re.search 扫描整个字符串并返回第一个成功的匹配。
两个函数在用法上十分相似,参数的意义如下:
参数 | 描述 |
---|---|
pattern | 要匹配的正则表达式 |
string | 待匹配的字符串 |
flags | 标志位,用于控制正则表达式的匹配方式,如:是否区分大小写 |
区别
它们之间的区别就是一个是从头匹配,一个不用从头匹配
例子:
import re
str = "hello world"
print(re.match(r'world',str)) #None
print(re.search(r'world',str).group()) #world
注意一下返回值,返回的并不是匹配的字符串,而是一个类对象<class ‘re.Match’>,调用group方法即可取出字符串。
总结
其实我个人喜欢直接使用findall,它的返回值是一个列表,下面直接看对比的例子把:
import re
str = "hello world world"
print(re.match(r'world',str)) #None
print(re.search(r'world',str).group()) #world
print(re.findall(r'world',str)) #['world', 'world']
findall返回值是一个列表,剩下的操作都是列表的操作,大家按需要选取即可,推荐使用findall。