preg_match(); //用於正則表達式的匹配,且只匹配一次 preg_match_all();//用於正則表達式的匹配,會對所有符合規則的都進行匹配 preg_replace(); //正則表達式替換函數 preg_splite(); //正則分割函數 preg_match ( mode, string subject , arraymatches ) 其中mode是正則規則,string subject是要匹配的字符串,arraymatches是匹配的結果數組 例子: [php] <?php $mode='/[89]/';//匹配8或者9 $str="djfkdsjk10903990sjdfdk"; preg_match($mode,$str,$arr); print_r($arr); ?> 輸出: [html] Array ( [0] => 9 ) preg_match_all ( mode, string subject , arraymatches ) 該函數和preg_match_all()函數的功能類似,不過該函數會匹配所有符合要求的內容,並將之存放到字符串中。 例子: [php] <?php $mode='/[89]/';//匹配8或者9 $str="dj33f44k88dsjk10903990sjdfdk"; preg_match_all($mode,$str,$arr); print_r($arr); ?> 輸出: [html] Array ( [0] => Array ( [0] => 8 [1] => 8 [2] => 9 [3] => 9 [4] => 9 ) ) preg_replace ( mixed pattern, mixed replacement,mixed subject [, int limit] ) 通過正則表達式來替換相關內容,類似之前學過的str_replace字符串替換,但功能要強於它。 特點:1、替換內容可以是一個正則也可以是數組正則 2、替換內容可以通過修正符e來解決替換執行內容 用途:替換一些比較復雜的內容上,也可以用於內容的轉換上 例子1——數組正則: [php] <?php $mode=array('/{title}/','/{author}/','/{url}/'); $re=array("code cloud","qianshou","http://codecloud.duapp.com/"); $str="標題:{title}<br>作者:{author}<br>地址:{url}"; echo "<hr/>"; if($tag=preg_replace($mode,$re,$str)){ echo $tag; }else{ echo "替換不成功!"; } ?> 輸出: [html] 標題:code cloud 作者:qianshou 地址:http://codecloud.duapp.com/ 例子2——ubb代碼的替換: [php] <?php $str="歡迎來到我的博客:[url]http://blog.csdn.net/qsyzb[/url]"; $re=preg_replace('/\[url\](.*)\[\/url\]/',"<a href=\"\\1\" target=\"new\">\\1</a>",$str); echo "<hr>".$re."<hr>"; ?> 輸出: [html <hr>歡迎來到我的博客:<a href="http://blog.csdn.net/qsyzb" target="new">http://blog.csdn.net/qsyzb</a><hr> preg_split ( string pattern, string subject [, intlimit [, int flags]] ) 通過正則表達式來切割相關內容,類似之前學過的explode切割函數,但explode只能按照一種方式切割有局限性。 例子: [php] <?php $mode='/[,.#]/'; $str='one,two.three#four'; if($tag=preg_split($mode,$str)){ print_r($tag); }else{ echo "替換不成功!"; } ?> 輸出: [html] Array ( [0] => one [1] => two [2] => three [3] => four )