引言: 在編寫處理字串的程式或網頁時,經常會有尋找符合某些複雜規則的字串
的需要。Regex就是用於描述這些規則的文法。
例:在判斷使用者郵件地址格式、手機號碼格式或者採集別人網頁內容時.
php也常常用到Regex php有兩個常用的Regex函數:preg_match和ereg。
我今天剛看了preg_match.它的具體寫法是preg_match(mode,string subject,array matches);
以下是我寫的一個example. 複製代碼 代碼如下:<?php
$mode="/[^8s]/";//匹配模組
$str="sssjj88d";//匹配內容
echo "<hr>";
if(preg_match($mode,$str,$arr)){ //匹配函數
echo "匹配成功".$arr[0];//$arr[0]:匹配結果集的第一個值
}
else{
echo "匹配失敗";
}
結果:
Regex(regular expression)"元字元":
*匹配前一個內容的0次或多次,即前一個內容任意都匹配
.匹配內容的0次1次或多次,但不包含斷行符號換行
+ 匹配前一個內容的1次或多次(除了空)。
| 選擇匹配類似PHP中的| (因為這個運算子合是弱類型導致前面最為整體匹配)
^ 匹配字串首部內容
$ 匹配字串尾部內容
{a,b},表示匹配前一個內容的次數,這個表示次數從a到b之間。
( ) 合并整體匹配,並放入記憶體,可使用\1 \2…依次擷取
以下是我用php寫的一個example: 複製代碼 代碼如下:<?php
$mode="/\d{2,4}(.*)\d{1,2}\\1\d{1,2}/";//匹配模組一般寫得越簡單越好
//$mode="/2009(.*)9\\1(10)/";
$str="2011/9/10";
if(preg_match($mode,$str,$arr)){
echo "匹配成功"."<br/><font color=red>".$arr[0]."</font><br/><br/><font size='+4' color=blue>教師節快樂</font>";
}
else{
echo "匹配失敗";
}
?>
結果: