主頁 > 知識庫 > php正則表達(dá)式中貪婪與非貪婪介紹

php正則表達(dá)式中貪婪與非貪婪介紹

熱門標(biāo)簽:地圖標(biāo)注商戶中心要收錢多少 宿遷智能外呼系統(tǒng)供應(yīng)商 400免費電話去哪申請 線上教育ai外呼系統(tǒng) 地圖標(biāo)注字母的軟件 鄂州人工智能電銷機(jī)器人軟件 css百度地圖標(biāo)注位置顯示 菏澤智能ai電銷機(jī)器人銷售公司 實用地圖標(biāo)注app

一、貪婪與非貪婪

什么叫貪婪,比如說要從字符串中td>面包一/td>td>面包二/td>吃面包,本來你只可以吃面包一,可是你貪心,于是就把第一個td>到最后一個/td>里面的兩個面包取出來了,你想多吃點,非貪婪也就是你不貪吃了,就只吃面包一。

我們來看看正則里面是怎么貪婪的

?php
$str = 'td>面包一/td>td>面包二/td>';
preg_match('/td>(.*)\/td>/',$str,$res);
print_r($res);

結(jié)果:

Array
(
    [0] => td>面包一/td>td>面包二/td>
    [1] => 面包一/td>td>面包二
)

0記錄的是整個字符,1表示的是第一次匹配。

怎么來限制貪婪?

?php
$str = 'td>面包一/td>td>面包二/td>';
preg_match('/td>(.*?)\/td>/',$str,$res);
print_r($res);
Array 
( 
 [0] => td>面包一/td> 
 [1] => 面包一 
)

在修飾匹配次數(shù)的特殊符號后再加上一個 "?" 號,則可以使匹配次數(shù)不定的表達(dá)式盡可能少的匹配。

在PHP中還可以通過修飾符來實現(xiàn),

?php
$str = 'td>面包一/td>td>面包二/td>';
preg_match('/td>(.*)\/td>/U',$str,$res);
print_r($res);

結(jié)果和上面一樣。這就是修飾符U的作用

二、預(yù)搜索

預(yù)搜索是一個非獲取匹配,不進(jìn)行存儲供以后使用。

1、正向預(yù)搜索 "(?=xxxxx)","(?!xxxxx)"

"(?=xxxxx)”:所在縫隙的右側(cè),必須能夠匹配上 xxxxx 這部分的表達(dá)式,

?php
$str = 'windows NT windows 2003 windows xp';
preg_match('/windows (?=xp)/',$str,$res);
print_r($res);

結(jié)果:

Array
(
    [0] => windows
)

這個是xp前面的windows,不會取NT和2003前面的。

格式:"(?!xxxxx)",所在縫隙的右側(cè),必須不能匹配 xxxxx 這部分表達(dá)式

?php
$str = 'windows NT windows 2003 windows xp';
preg_match_all('/windows (?!xp)/',$str,$res);
print_r($res);

結(jié)果:

Array
(
[0] => Array
(
[0] => windows 這個是nt前面的
[1] => windows 這個是2003前面的
)

)

從這里可以看出,預(yù)搜索不進(jìn)行存儲供以后使用。

與會存儲的對比下。

?php
$str = 'windows NT windows 2003 windows xp';
preg_match_all('/windows ([^xp])/',$str,$res);
print_r($res);

結(jié)果:

Array
(
[0] => Array 全部模式匹配的數(shù)組

(
[0] => windows N
[1] => windows 2
)

[1] => Array 子模式所匹配的字符串組成的數(shù)組,通過存儲取得。
(
[0] => N
[1] => 2
)

)

2、反向預(yù)搜索 "(?=xxxxx)","(?!xxxxx)"

"(?=xxxxx)" :所在縫隙的 "左側(cè)”能夠匹配xxxxx部分。

?php
$str = '1234567890123456';
preg_match('/(?=\d{4})\d+(?=\d{4})/',$str,$res);
print_r($res);

結(jié)果:

Array
(
    [0] => 56789012
)

匹配除了前4個數(shù)字和后4個數(shù)字之外的中間8個數(shù)字
"(?!xxxxx)":所在縫隙的“左側(cè)”不能匹配xxxx部分。

?php
$str = '我1234567890123456';
preg_match('/(?!我)\d+/',$str,$res);
print_r($res);

結(jié)果:
Array
(
    [0] => 234567890123456
)

 
三、preg和ereg的區(qū)別


PHP同時使用兩套正則表達(dá)式規(guī)則,一套是由電氣和電子工程師協(xié)會(IEEE)制定的POSIX Extended 1003.2兼容正則(事實上PHP對此標(biāo)準(zhǔn)的支持并不完善),另一套來自PCRE(Perl Compatible Regular Expression)庫提供PERL兼容正則。 PHP5.3開始POSIX被刪除了。

preg_match 比 ereg效率高。

您可能感興趣的文章:
  • php使用正則表達(dá)式獲取字符串中的URL
  • Ajax和PHP正則表達(dá)式驗證表單及驗證碼
  • PHP正則表達(dá)式抓取某個標(biāo)簽的特定屬性值的方法
  • PHP正則表達(dá)式入門教程(推薦)
  • PHP正則表達(dá)式過濾html標(biāo)簽屬性(DEMO)
  • php正則表達(dá)式驗證(郵件地址、Url地址、電話號碼、郵政編碼)
  • 非常重要的php正則表達(dá)式詳解
  • php獲取超鏈接文本內(nèi)容的正則表達(dá)式(五種方法)
  • php正則表達(dá)式完全教程之精華篇
  • 史上最全的PHP正則表達(dá)式(手機(jī)號需要加上177-***)

標(biāo)簽:三亞 綿陽 咸陽 恩施 池州 鞍山 梅州 六安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《php正則表達(dá)式中貪婪與非貪婪介紹》,本文關(guān)鍵詞  php,正則,表達(dá)式,中,貪婪,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《php正則表達(dá)式中貪婪與非貪婪介紹》相關(guān)的同類信息!
  • 本頁收集關(guān)于php正則表達(dá)式中貪婪與非貪婪介紹的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章