报错原因:没有匹配到符合正则表达式的内容,但又调用了group方法。
解决方法:1、如果不确定能够匹配到内容时,可以先判断,再调用group方法。
import re
strs = "#53e45k"
if re.match("^#\d{2}", strs): #匹配以#号加2个数字开头的字符串
contents = re.match("^#\d{2}",strs).group()
print("匹配到的内容是:%s" % contents)
else:
print("没有匹配到正则内容!")
# 结果是:匹配到的内容是:#53
2、如果确定匹配的内容中有符合的内容,但不一定是在字符串的开始位置,用searc方法。
import re
strs = "53e#45#67k"
if re.search("#\d{2}", strs): #匹配以#号加2个数字的字符串
# search方法会返回匹配到第一个符合条件的字符串
contents = re.search("#\d{2}",strs).group()
print("匹配到的内容是:%s" % contents)
else:
print("没有匹配到正则内容!")
# 结果是:匹配到的内容是:#45