import re if __name__ == '__main__': bt = 'bat|bet|bit' m = re.match(bt, 'bet') if m is not None: result = m.group() print(result) m = re.match(bt, 'batbet') if m is not None: result = m.group() print(result) m = re.match(bt, 'ggbet') if m is not None: result = m.group() print(result) # 控制台打印出来的结果为: bet bat
从上面的信息来看,python的 re 模块中的 match方法这种用法只能匹配出字符串开始是否包含指定的部分,而且只读取返回的结果只有一条数据,不知道大家理解了没有,没有理解可以将上面的代码直接复制运行,当然这句话也不完全对,上面代码如果换成这样的话就说的不对了
bt = '(bat).(bet).(bit)' m = re.match(bt, 'batmbetubit') if m is not None: result = m.group(3) print(result)
bt = 'bit' m = re.search(bt, 'hfgkfkjbit') if m is not None: result = m.group() print(result)
re中的search这个方法的就可以从一整句中查询是否包含需要的部分,而不仅仅的是查找开头有没有
a = "123abc456" print(re.search("([0-9]*)([a-z]*)([0-9]*)", a).group(0)) # 123abc456,返回整体 print(re.search("([0-9]*)([a-z]*)([0-9]*)", a).group(1) ) # 123 print(re.search("([0-9]*)([a-z]*)([0-9]*)", a).group(2)) # abc print(re.search("([0-9]*)([a-z]*)([0-9]*)", a).group(3)) # 456 print("-"*50) m = "(bet)...(bat)" result = re.search(m, "betljhbat") print(result.group(0)) # 返回整体 print(result.group(1)) # 返回bet print(result.group(2)) # 返回bat