Python里数量词默认是贪婪的(在少数语言里默认非贪婪),总是尝试匹配尽可能多的字符,非贪婪则相反,总是尝试尽可能少的字符。
在 “*”, “?”, “+”,"{m,n}" 后面加上?,便贪婪变成非贪婪。
贪婪:
"""
1.导入模块
2.通过match方法,验证正则
3.判断、验证是否成功
4.如果成功,获取匹配的结果
"""
# 1.导入模块
import re
# 2.通过match方法,验证正则
# re.match('正则表达式','要验证/检测的字符串')
# 贪婪:满足正则的情况下,尽可能少的取内容。
# 把贪婪模式该为非贪婪模式,需要使用符号:?在 + * ? {}后面添加?可以变成贪婪
result = re.match('aaa\d+', 'aaa123456')
# 3.判断、验证是否成功
if result:
print('匹配成功')
# 4.如果成功,获取匹配的结果
print(result.group())
else:
print('匹配失败')
运行结果
匹配成功
aaa123456
非贪婪:把贪婪模式该为非贪婪模式,需要使用符号:?在+ * ? {}后面添加?可以变成贪婪
"""
1.导入模块
2.通过match方法,验证正则
3.判断、验证是否成功
4.如果成功,获取匹配的结果
"""
# 1.导入模块
import re
# 2.通过match方法,验证正则
# re.match('正则表达式','要验证/检测的字符串')
# 贪婪:满足正则的情况下,尽可能少的取内容。
# 把贪婪模式该为非贪婪模式,需要使用符号:?在+ * ? {}后面添加?可以变成贪婪
# result = re.match('aaa\d+', 'aaa123456')
result = re.match('aaa(\d+?)','aaa123456')
# 3.判断、验证是否成功
if result:
print('匹配成功')
# 4.如果成功,获取匹配的结果
print(result.group())
else:
print('匹配失败')
运行结果
匹配成功
aaa1