Python中的数量词默认是贪婪模式,会尽可能地去匹配更多的字符。
非贪婪模式则相反,尽可能少地匹配字符。
'*',*前面的字符匹配0次或多次(贪婪模式)
'+',+前面的字符匹配1次或多次(贪婪模式)
'?',?前面的字符匹配0次或1次(贪婪模式)
'*?,+?,??',上面三个的非贪婪模式
'{m,n}',前面的字符匹配m-n次(贪婪模式)
'{m,n}?',上面的非贪婪模式
示例
import re
sample_string = 'www.baidu.com/path'
#‘+’贪婪模式,匹配1个或多个
request = re.match(r'\w+', sample_string)
print(request)
#‘+?’非贪婪模式,匹配1个
request = re.match(r'\w+?', sample_string)
print(request)
#{2,5}贪婪模式最少匹配2个,最多匹配5个
request = re.match(r'\w{2,5}', sample_string)
print(request)
#{2,5}?非贪婪模式,匹配两个
request = re.match(r'\w{2,5}?', sample_string)
print(request)
---------------
输出: