您好,登錄后才能下訂單哦!
了解php使用正則表達式實現(xiàn)替換的方法?這個問題可能是我們?nèi)粘W習或工作經(jīng)常見到的。希望通過這個問題能讓你收獲頗深。下面是小編給大家?guī)淼膮⒖純?nèi)容,讓我們一起來看看吧!
php正則表達式實現(xiàn)替換的方法:首先創(chuàng)建一個PHP示例文件;然后定義一個字符串;最后通過正則表達式“preg_replace("/[0-9]/","",$str);”去掉字符串中所有數(shù)字即可。
PHP正則替換preg_replace函數(shù)的使用
<?php $str="as2223adfsf0s4df0sdfsdf"; echo preg_replace("/0/","",$str);//去掉0字符,此時相當于 replace的功能, preg_replace("/0/","A",$str); 這樣就是將0變成A的意思了 echo preg_replace("/[0-9]/","",$str);//去掉所有數(shù)字 echo preg_replace("/[a-z]/","",$str); //這樣是去掉所有小寫字母 echo preg_replace("/[A-Z]/","",$str); //這樣是去掉所有大寫字母 echo preg_replace("/[a-z,A-Z]/","",$str); //這樣是去掉所有字母 $str="as2223adfsAAf0s4df0s中國人dD中南海DDfsdf"; echo preg_replace("/[a-z,A-Z,0-9]/","",$str); //去掉所有字母和數(shù)字 ?> 經(jīng)過以上的例子,相信大家知道,[ ] 和里面的,有什么作用了。也可以看到,匹配的字符串必須加 / /(看例子的第一個參數(shù)) <?php $str="acsdcs<55555555>sc<6666>sdcd"; echo preg_replace("/<.*>/","",$str); //這個是表示去除以<開頭,以>結(jié)尾的那部份,輸出結(jié)果是:acsdcssdcd 注意:上面的 .* 是表示任何字符,也就是說不管<>包住的是什么都去掉其中. 表示任意字符, * 表示任意個數(shù) 現(xiàn)在我們來改動一下,如果不想是任何個數(shù)呢? $str="acsdcs<55555555>sc<6666>sdcd"; echo preg_replace("/<.{4}>/","",$str); //此時輸出:acsdcs<55555555>scsdcd因為{4}指定了條件:<>內(nèi)為4個字符的才滿足條件,所以<55555555>不符合條件,沒有被替換。 注意:這時我們又學到了一個知識點{數(shù)字} 表示指定前面的個數(shù),*就表示是任意個(0--無限個) 表示重復(fù)次數(shù)的除了 *, {指定次數(shù)} 表示,還有很多表達形式: <?php $str="acsdcs<55555555>sc<6666>sd<>cd"; echo preg_replace("/<[0-9]*>/","",$str); //輸出acsdcscd echo "<hr>"; echo preg_replace("/<[0-9]+>/","",$str); //輸入acsdcsscsd<>cd ?> 上面的例子只要是為了 表達 * 與+的區(qū)別 ,* 表示重復(fù)0數(shù)或n 次,而+ 表示1次以上,即一例中<[0-9]+ >表示<>里面至少要有一個數(shù)字才符合條件。 相信這時大家知道,為什么上例中用* 和用+輸出的結(jié)果不同了吧 再來: <?php $str="acsdcs<55555555>sc<6666>sd<>cd"; echo preg_replace("/<[0-9]?>/","",$str); //輸出acsdcs<55555555>sc<6666>sdcd ?> 看[0-9]? 這里的?表示要是0次或1 次,超過1次又不符合條件了。 總結(jié)一下,上面我們學會了 * + ? 和大括號{}表示重復(fù)次數(shù)的方法。 ---------------------------------------------------------------------------------------------------- $s=preg_replace("/(.*?[月票|求|更].*?)/i","",$s); preg_match_all('/href=\"([0-9]+)\.shtm">(.+?)<\/a>/i',$s,$arr_dstorycate); print_r($arr_dstorycate); ---------------------------------------------------------------------------------------------------- preg_match_all("/<img.*?src=[\\\'| \\\"](.*?(?:[\.gif|\.jpg]))[\\\'|\\\"].*?[\/]?>/i",$content,$arr_dstorycate); print_r($arr_dstorycate);
補充:
.$pattern是數(shù)組,$replace也是數(shù)組,則中對應(yīng)的 元素進行替換
php
preg_replace有五個參數(shù),有三個是必須參數(shù)
Preg_replace(mixed $pattern, mixed $replacement, mixed $subject [,int $limit = -1 [,int $count ]]);
$pattern 可以是字符串,字符串數(shù)組,或者preg
$replace 是用于替換的字符串或字符串數(shù)組
$subject 目標字符串或者目標字符串數(shù)組
$limit 每個模式在每個$subject上最大的替換次數(shù),默認是-1(無限次)
$count 返回在目標字符串所替換的次數(shù)
在repalce與pattern中有幾點要注意的
1.$pattern是數(shù)組,$replace也是字符串,那么所有模式都使用這個字符串來匹配;
2.$pattern是數(shù)組,$replace也是數(shù)組,則中對應(yīng)的 元素進行替換
3.如果數(shù)組$pattern大于$replace,則多出來的$pattern用空的字符串進行替換,
$replace少于$patterns,則匹配到的值全部用空字符串來替換
4.對于上面例子中出現(xiàn)的${1},${2},${3},這個叫做包含后向引用,里面的數(shù)字代表原子出現(xiàn)的位數(shù),有兩種寫法,一種是\\n,一種是${n},推薦使用第二種寫法.會把目標字符串匹配到的pattern中的原子,按照要求變化目標字符串的格式,或者匹配的原子原樣輸出(這里舉兩個例子)
把時間按照 下劃線分割開來,${3}就是匹配的到$patterns中的第三個原子((\d{1,2})),${4}就是匹配的到$patterns中的第四個原子((\d{1,2}))以此類推,
例如大家熟悉的smarty模板引擎中編譯后替換的方法
5.第四個參數(shù)的$limit的使用,第四個參數(shù)的意思是每個模式在每個subject上進行替換的最大次數(shù)
如果limit為n,它只用正則替換n次
6.第五個參數(shù)$count的使用,$count的意思是,subject目標字符串被替換的次數(shù),拿第五點的例子來說
上面代碼中的例子運行結(jié)果如下:
附加:
preg_replace與str_replace的關(guān)系是什么呢?
我們可以理解為str_replace是preg_repalce的一個子集.只是str_replace中的第一個參數(shù)寫的是string,而preg_replace寫的是一個正則表達式
感謝各位的閱讀!看完上述內(nèi)容,你們對php使用正則表達式實現(xiàn)替換的方法大概了解了嗎?希望文章內(nèi)容對大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。