php正則 貪婪模式與懶惰模式

2021-08-26 06:13:28 字數 444 閱讀 1067

當正規表示式中包含能接受重複的限定符時,通常的行為是(在使整個表示式能得到匹配的前提下)匹配盡可能多的字元。考慮這個表示式:a.*b,它將會匹配最長的以a開始,以b結束的字串。如果用它來搜尋aabab的話,它會匹配整個字串aabab。這被稱為貪婪匹配。

有時,我們更需要懶惰匹配,也就是匹配盡可能少的字元。前面給出的限定符都可以被轉化為懶惰匹配模式,只要在它後面加上乙個問號?。這樣.*?就意味著匹配任意數量的重複,但是在能使整個匹配成功的前提下使用最少的重複。現在看看懶惰版的例子吧:

a.*?b匹配最短的,以a開始,以b結束的字串。如果把它應用於aabab的話,它會匹配aab(第一到第三個字元)和ab(第四到第五個字元)。

注意, 若pattern中使用了/i 表示不區分大小寫

/s 表示.還匹配空白字元

/u 表示模式反轉, 即貪婪匹配模式變成懶惰匹配模式, 懶惰匹配模式變成貪婪匹配模式

php正則 貪婪模式與懶惰模式

當正規表示式中包含能接受重複的限定符時,通常的行為是 在使整個表示式能得到匹配的前提下 匹配盡可能多的字元。考慮這個表示式 a.b 它將會匹配最長的以a開始,以b結束的字串。如果用它來搜尋aabab 的話,它會匹配整個字串aabab。這被稱為貪婪匹配。有時,我們更需要懶惰匹配,也就是匹配盡可能少的字...

PHP正則貪婪 懶惰匹配模式

當正規表示式中包含能接受重複的限定符時,通常的行為是 在使整個表示式能得到匹配的前提下 匹配盡可能多的字元。例如以下表示式將匹配以a開始,以b結束的最長字串 a.b 如果用來搜尋 aabab 它會匹配整個字串 aabab 這就是貪婪匹配。有時,需要匹配盡可能少的字元,也就是懶惰匹配。前面給出的限定符...

正規表示式貪婪模式與懶惰模式

正規表示式貪婪匹配模式,對於初學者,往往也很容易出錯。有時候需要匹配乙個段 內容,發現匹配與想要不一致。發現原來,跟貪婪模式有關係。如下,我們看下例子 字串有 我們想匹配內容,正規表示式如下 1 h3開頭與結尾,都作為普通字元 2 中間可以出現任意字元,個數可以是0個或者多個,正規表示式可以用 代表...