溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

php正則表達(dá)式中貪婪與非貪婪的示例分析

發(fā)布時(shí)間:2021-09-01 09:44:48 來源:億速云 閱讀:256 作者:小新 欄目:互聯(lián)網(wǎng)科技

小編給大家分享一下php正則表達(dá)式中貪婪與非貪婪的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

一、貪婪與非貪婪

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

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

<?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記錄的是整個(gè)字符,1表示的是第一次匹配。

怎么來限制貪婪?

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

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

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

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

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

二、預(yù)搜索

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

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
)

這個(gè)是xp前面的windows,不會(huì)取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 這個(gè)是nt前面的
[1] => windows 這個(gè)是2003前面的
)

)

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

與會(huì)存儲(chǔ)的對(duì)比下。

<?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ù)組,通過存儲(chǔ)取得。
(
[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個(gè)數(shù)字和后4個(gè)數(shù)字之外的中間8個(gè)數(shù)字
"(?<!xxxxx)":所在縫隙的“左側(cè)”不能匹配xxxx部分。

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

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

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

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

preg_match 比 ereg效率高。

以上是“php正則表達(dá)式中貪婪與非貪婪的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI