PHP下常用Regex整理
最後更新:2017-02-28
來源:互聯網
上載者:User
--------------------------------------------------------- 正則收藏
手機號碼:
$mode = "/^1[358]\d{9}/";
郵箱地址:
$mode = "/^[a-z][-_\.]?[a-z\d]*@[a-z0-9]+[\.][a-z]{2,4}/i";
---------------------------------------------------------- 正則基礎
$mode = "/^1[358]\d{9}/i";
匹配模組必須以 / / 開始和結束,第二個 / 後可以加模式修正符
原子
①a-z A-Z _ 0-9 //最常見的字元
②(abc) //用圓括弧括起來起來的單元符號
③[abcs] [^abd] //用方括弧括起來的原子表,
原子表中的^代表排除或相反內容
\d 包含所有數字[0-9]
\D 除所有數字外[^0-9]
\w 包含所有英文字元[a-zA-Z_0-9]
\W 除所有英文字元外[^a-zA-Z_0-9]
\s 包含空白地區如斷行符號、換行、分頁等 [\f\n\r]
元字元
* 匹配前一個內容的0次1次或多次
+ 1次或多次
? 0次或1次
. 代表任意一個字元(除了斷行符號換行)
相當與php的 (“或”的意思)
^ 強制匹配字串首部內容
$ 強制匹配字串尾部內容
[^abc] 匹配除了a或b或c之外的內容
\b 匹配單詞邊界,邊界可以是空格或者特殊符號
\B 匹配除帶單詞邊界以外的內容
{m} 匹配前一個內容的重複次數為M次
{m,} 匹配前一個內容的重複次數大於等於M次
{m,n} 匹配前一個內容的重複次數M次到N次
( ) 整體匹配,並放入記憶體,可使用\\1 或 \\2 …依次擷取
優先順序:依次降低
( ) 圓括弧因為是記憶體處理所以最高
* ? + { } 重複匹配內容其次
^ $ \b 邊界處理第三
條件處理第四
最後按照運算順序計算匹配
常用修正符: $mode = "/正則/U";
i 正則內容在匹配時候不區分大小寫(預設是區分的)
m 在匹配首內容或者尾內容時候採用多行識別匹配
S 將斷行符號轉化為空白格
x 忽略正則中的空白
A 強制從頭開始匹配
D 強制$匹配尾部無任何內容 \n
U 禁止貪婪匹配,只跟蹤到最近的一個匹配符並結束,
常用在採集程式上的Regex
應用
preg_match_all ( string pattern, string subject, array matches [, int flags] )
截取比較詳細的內容,採集網頁,分析文本
preg_replace ( mixed pattern, mixed replacement, mixed subject [, int limit] )
preg_replace ( mixed pattern, mixed replacement, mixed subject [, int limit] )
提示 1、替換內容可以是一個正則也可以是數組正則
2、替換內容可以通過修正符e來解決替換執行內容
preg_split ( string pattern, string subject [, int limit [, int flags]] )
通過Regex來切割相關內容,類似之前學過的explode切割函數,但explode
只能按照一種方式切割有局限性。
------------------------------------------------- 調試代碼
[code]
<?php
$mode = "/^[a-z][-_\.]?[a-z\d]*@[a-z0-9]+[\.][a-z]{2,4}/i";
$str = "a12345@jb51.net";
echo $str.'<hr>';
if(preg_match($mode, $str, $arr)){
echo 'succeed -- <font color=red>'.$arr[0];
}else{
echo 'failed';
}
?>
[code]