这是在学习过程中遇到的一个例子
#!/usr/bin/python3
import re
line = "Cats are smarter than dogs"
# .* 表示任意匹配除换行符(\n、\r)之外的任何单个或多个字符
# (.*?) 表示"非贪婪"模式,只保存第一个匹配到的子串
matchObj = re.match( r'(.*) are (.*?) .*', line, re.M|re.I)
if matchObj:
print ("matchObj.group() : ", matchObj.group())
print ("matchObj.group(1) : ", matchObj.group(1))
print ("matchObj.group(2) : ", matchObj.group(2))
else:
print ("No match")
上述实例执行结果:
matchObj.group() : Cats are smarter than dogs
matchObj.group(1) : Cats
matchObj.group(2) : smarter
从上向下捋顺,找到不懂的位置。
一、(.*?)表示“非贪婪”模式(#不懂,pass。),只保存第一个匹配到的子串(#这里字符串的长度包括空格在内不能小于2,小于2时输出结果是No match)
二、match函数(#在起始位置匹配)
三、r ' (.*) are (.*?)