国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Regex > 正文

php中常用的正則表達式的介紹及應用實例代碼

2020-03-16 21:14:20
字體:
來源:轉載
供稿:網友
在編寫處理字符串的程序或網頁時,經常會有查找符合某些復雜規則的字符串的需要。正則表達式就是用于描述這些規則的語法。
 
 

更全面的實例,可以參考
最常用的PHP正則表達式收集整理
http://www.survivalescaperooms.com/shouce/jiaoben/zhengze/


以下內容為php中常用的正則,正則是一門通用性的語法,可以在網上下載更全面的正則,提供學習! 
作用:分割,匹配,查找,替換 

1,php中兩個常用的正則函數 

preg_match(mode,string subject,array matches); 

mode ---模塊,正則的語法 
subject ---正則內容 
matches ---正則的結果 

ereg(mode,string subject,array regs); 

以上兩個函數返回的為true或flase。 

2,正則表達式包含的元素 

一,原子(普通字符:a-z,A-Z,0-9,原子表,轉義符) 
二,元字符(有特殊功能的字符) 
三,模式修政符(系統內置部分字符i,m,S,U...) 

3,正則表達式中的“原子” 

一,a-z A-Z_0-9 //最常見的字符 
二,(bfw)(sda) //用圓括號包含起來的單元符號,一個括號表示一個整體 
三,[sdwe][^mjnb] //用方括號包含起來的原子表,原子表中^代表排除或相反內容 
四,轉義字符 
/d 包含所有的數字[0-9] 
/D 除所有數字外[^0-9] 
/w 包含所有英文字符[a-zA-Z_0-9] 
/W 除所有英文字符外[^a-zA-Z_0-9] -----匹配特殊字符 
/s 包含空白區域 如回車,換行,分頁等[/f/n/r] 

4,正則表達式元字符 

* 匹配前一個內容的0次或多次 
. 匹配內容的0次或多次,但不包含回車換行 
+ 匹配前一個內容的1次或多次 
? 匹配前一個內容的0次或1次 
| 選擇匹配,類似php中||的用法 
^ 匹配字符串首部的內容 
$ 匹配字符串尾部內容 
/b 匹配單詞邊界,邊界可以是空格或者特殊符號 
/B 匹配除帶單詞邊界的意外內容 
{m} 匹配前一個內容的重復次數為m次 
{m,} 匹配前一個內容的重復次數大于等于m次 
{m,n} 匹配前一個內容的重復次數m次到n次 
() 合并整體匹配,并放入內存,可使用//1//2依次獲取調用 

5,正則表達式中的 模式修正符 
(1)運算順序 
遵循從左到右的的運算規則 

()圓括號是最高的 第一優先級 
* ? + {} 重復匹配內容 為第二優先級 
^ $ /b 邊界處理 為第三優先級 
| 條件處理 為第四 
最后按照運算順序計算匹配 

(2)模式修正符 

是為正則表達式增強和補充的一個功能,使用在正則之外 

例子:/正則/U U就表示一個模式修正符 

一下幾個為php中常用的:(注意:區分大小寫) 
i 正則內容在匹配時候不區分大小寫(默認是區分的) 
m 在匹配首內容或者尾內容時候采用多行識別匹配 
s 將轉義回車取消是為單位匹配如.匹配的時候 
x 忽略正則中的空白 
A 強制從頭開始匹配 
D 強制$匹配尾部任何內容/n 
U 禁止貪mei匹配,只跟蹤到最近的一個匹配符并結束,常用在采集程序的正則表達式 

例子: 

復制代碼代碼如下:

<?php 
$pot="//d{1,4}(.*)/d{1,2}//1/d{1,2}/"; 
$cont="2010-12-08"; 
if(preg_match($pot,$cont,$arr)){ 
echo "匹配成功".$arr[0]; 
}else{ 
echo "匹配不成功"; 

?> 

6,全局匹配函數 

preg_match_all(string pattern,string subject,array matches[,int flags]) 

主要功能:截取比較詳細的內容,采集網頁,分析文本 
例子: 
復制代碼代碼如下:

<?php 
$str="aaa<bbb>ccc<dddd>eee"; 
$mode="/<.*>/U"; 

if(preg_match_all($mode,$str,$arr)){ 
echo "匹配成功".print_r($arr); 
}else{ 
echo "匹配不成功"; 


?> 

7,替換函數 
preg_replace(mixed pattern,mixed replacement,mixed subject[,int limit]) 

與str_replace字符串替換相比,功能更加強大 

注意:1,替換內容可以是一個正則也可以是一個數組正則 
2,替換內容可以通過修正符e來解決替換執行內容 

用途:替換一些比較復雜的內容上,也可以用于內容的轉換上 
例子: 
復制代碼代碼如下:

<?php 
$str="aaa<bbb>ccc<dddd>eee"; 
$mode="/<.*>/U"; 
echo preg_replace($mode,"替換內容",$str); 
?> 

例2:數組正則替換 
復制代碼代碼如下:

<?php 
$str="aaa<bbb>ccc<dddd>eee"; 
$mode=array("/<bbb>/","/<dddd>/"); 
$m=array("/<yyy>/","/<mmmm>/"); 

echo preg_replace($mode,$m,$str); 

?> 
例3:md5正則替換 
<?php 
$str="密碼1:bbb/n密碼2:BBB"; 
$mode="/(bbb)/ie"; 

//參數1為正則替換一次,如過2,這連后面的大寫b也正則匹配了 
//preg_replace($mode,"md5(//1)",$str,1); 
echo preg_replace($mode,"md5(//1)",$str); 
?> 


8,正則切割函數 
preg_split(string pattern,string subject[,int limit[,int flags]]) 

通過正則表達式來切割相關內容,類似之前學過的explode切割函數,但explode只能按照一種方式切割有局限性 

例子: 
復制代碼代碼如下:

<?php 
$str="asd,sdsa,efsd,we。dce,sec"; 
$mode="/[,.。]/"; 
$arr=preg_split($mode,$str); 
for($i=0;$i<count($arr);$i++){ 
echo $arr[$i]."<br>"; 

?> 

 

 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 商河县| 肇庆市| 西贡区| 龙里县| 白玉县| 始兴县| 金寨县| 剑河县| 卫辉市| 大足县| 正定县| 九龙县| 班玛县| 灌南县| 长宁县| 姚安县| 黄大仙区| 仁化县| 太湖县| 无极县| 濉溪县| 阿尔山市| 读书| 高邮市| 海南省| 广平县| 汕尾市| 阿图什市| 福清市| 新营市| 普格县| 洪洞县| 十堰市| 随州市| 临清市| 嘉黎县| 裕民县| 平塘县| 阳朔县| 寿光市| 宁乡县|