在PHP正則表達(dá)式中,貪婪匹配是指盡可能多地匹配字符
?
:在正則表達(dá)式的量詞(如*
、+
、{n,m}
)后面添加一個(gè)問(wèn)號(hào)?
,表示非貪婪匹配。例如,要匹配字符串中的最短的子串,可以使用以下正則表達(dá)式:
$pattern = '/\d{1,2}?/';
$string = '12345';
preg_match($pattern, $string, $matches);
print_r($matches); // 輸出:Array ( [0] => 1 )
在這個(gè)例子中,\d{1,2}
表示匹配1到2個(gè)數(shù)字,但由于后面添加了非貪婪限定符?
,所以只匹配了最短的子串1
。
preg_match_all()
函數(shù):如果你想要找到字符串中所有滿足條件的子串,可以使用preg_match_all()
函數(shù)。這個(gè)函數(shù)會(huì)返回一個(gè)包含所有匹配結(jié)果的數(shù)組。例如:
$pattern = '/\d{1,2}/';
$string = '12345';
preg_match_all($pattern, $string, $matches);
print_r($matches); // 輸出:Array ( [0] => Array ( [0] => 1 [1] => 2 ) [1] => Array ( [0] => 3 [1] => 4 ) [2] => Array ( [0] => 5 ) )
在這個(gè)例子中,\d{1,2}
表示匹配1到2個(gè)數(shù)字,由于沒(méi)有添加非貪婪限定符?
,所以匹配了所有滿足條件的子串。
總之,要處理PHP正則表達(dá)式中的貪婪匹配,可以使用非貪婪限定符?
或者使用preg_match_all()
函數(shù)來(lái)找到所有滿足條件的子串。