您好,登錄后才能下訂單哦!
本篇內容主要講解“PHP正則之正向預查與反向預查是什么”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“PHP正則之正向預查與反向預查是什么”吧!
php是一個嵌套的縮寫名稱,是英文超級文本預處理語言,它的語法混合了C、Java、Perl以及php自創(chuàng)新的語法,主要用來做網站開發(fā),許多小型網站都用php開發(fā),因為php是開源的,從而使得php經久不衰。
了解正向預查&反向預查前,我們先要知道正則的2個函數(shù):preg_match_all 、 preg_replace
正向或反向預查都是非獲取匹配,不進行存儲供以后使用。
(?:pattern) 匹配結果
(?=pattern) 正向匹配
(?!pattern) 正向不匹配
(?<=pattern) 反向匹配。
(?<!pattern) 反向不匹配。
什么叫非獲取匹配(非捕獲匹配),請看例子
$str = 'XXXXjava6java7XXXX'; $perg = "/java(6|7)/"; //匹配java6 獲取 java preg_match_all($perg, $str, $matchs); $str1 = preg_replace($perg, '\0', $str); //"XXXXjava6java7XXXX" $str2 = preg_replace($perg, '\1', $str); //"XXXX67XXXX"
$matchs輸出結果:
array(2) { [0]=> array(2) { [0]=> string(5) "java6" [1]=> string(5) "java7" } [1]=> array(2) { [0]=> string(1) "6" [1]=> string(1) "7" } }
$str1輸出結果:
string(18) "XXXXjava6java7XXXX"
$str2輸出結果:
string(10) "XXXX67XXXX"
知道了preg_match_all的用法,對于上面的輸出結果應該很清楚,[n]的后向引用。 [0]中保存的是匹配結果的全文,數(shù)組的個數(shù)=匹配到結果的個數(shù),[1] 中保存的匹配結果中對應括號中匹配的結果(子組),.....[n]第n個括號中的匹配內容。
preg_replace 中的 \0,\1,也是對匹配結果的引用。
$str1 = preg_replace($perg, '\0', $str); //"XXXXjava6java7XXXX", 用全文中的匹配結果進行對應替換
$str2 = preg_replace($perg, '\1', $str); //"XXXX67XXXX",用括號中的子結果進行對應的替換
我們對比知道,\0 的替換內容,是匹配全文的中內容,對應元素的替換。
$str = 'XXXXjava6java7XXXX'; $perg = "/java(?:6|7)/"; preg_match_all($perg, $str, $matchs); $str1 = preg_replace($perg, '\0', $str); //"XXXXjava6java7XXXX"
$match 輸出結果:
array(1) { [0]=> array(2) { [0]=> string(5) "java6" [1]=> string(5) "java7" } }
$str1輸出結果:
string(18) "XXXXjava6java7XXXX"
對比例1中,我們發(fā)現(xiàn)沒有括號匹配的結果,這就是我們說的非獲取匹配,只匹配全本結果,不捕獲括號中的子結果。
$str = 'XXXXjava6java7XXXX'; $perg = "/java(?=6|7)/"; preg_match_all($perg, $str, $matchs); $str1 = preg_replace($perg, '\0', $str); //"XXXXjava6java7XXXX" var_dump($matchs, $str1); die;
輸出結果:
array(1) { [0]=> array(2) { [0]=> string(4) "java" [1]=> string(4) "java" } } string(18) "XXXXjava6java7XXXX"
相比上面的我們匹配的結果中沒有 6,7
$str = 'XXXXjava6java7XXXX'; $perg = "/java(?!6)/"; //不匹配java6 preg_match_all($perg, $str, $matchs); $str1 = preg_replace($perg, '', $str); //"XXXXjava67XXXX" var_dump($matchs, $str1); die;
輸出結果:
array(1) { [0]=> array(1) { [0]=> string(4) "java" } } string(14) "XXXXjava67XXXX"
這里匹配的到結果是java7,但是由于我們用了非獲取匹配,就不存貯7,剩下的就是java了
主要:不管是怎么替換,如果我們只要用的是 \0(完整匹配結果) 中的結果進行替換,相當于匹配到了什么就替換掉原字符串中的什么,實際上原字符串沒變化,
(?<=pattern) 反向匹配。(?<=J)a,匹配緊跟字母J后面的a,結果Java6 Java
(?<!pattern) 反向不匹配。(?<!J)a,不匹配緊跟字母J后面的a,結果Java6 Java
$str = 'XXXXjava6java7XXXX'; $perg = "/(?<!6)java/"; //不匹配前端有6的java preg_match_all($perg, $str, $matchs); $str1 = preg_replace($perg, '', $str); //"XXXX6java7XXXX" var_dump($matchs, $str1); die;
輸出結果:
array(1) { [0]=> array(1) { [0]=> string(4) "java" } } string(14) "XXXX6java7XXXX"
總結:
正向預查,反向預查,就是方向不同。
正向預查時,具體字符串在左邊,/java(?:6|7)/,從字符串開始向右查找;
反向則在右邊: / (?<!J)a /,從字符串向反方向(左)查找。
到此,相信大家對“PHP正則之正向預查與反向預查是什么”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。