正则表达式preg_replace学习

  1. <?php  
  2. $str="as2223adfsf0s4df0sdfsdf";  
  3. echo preg_replace("/0/","",$str);//去掉0字符,此时相当于 replace的功能, preg_replace("/0/","A",$str); 这样就是将0变成A的意思了  
  4. echo preg_replace("/[0-9]/","",$str);//去掉所有数字  
  5. echo preg_replace("/[a-z]/","",$str); //这样是去掉所有小写字母  
  6. echo preg_replace("/[A-Z]/","",$str); //这样是去掉所有大写字母  
  7. echo preg_replace("/[a-z,A-Z]/","",$str); //这样是去掉所有字母  
  8. $str="as2223adfsAAf0s4df0s中国人dD中南海DDfsdf";  
  9. echo preg_replace("/[a-z,A-Z,0-9]/","",$str); //去掉所有字母和数字  
  10. ?>  
  11. 经过以上的例子,相信大家知道,[ ] 和里面的,有什么作用了。也可以看到,匹配的字符串必须加 / /(看例子的第一个参数)  
  12.   
  13. <?php  
  14. $str="acsdcs<55555555>sc<6666>sdcd";  
  15. echo preg_replace("/<.*>/","",$str);  
  16.   
  17. //这个是表示去除以<开头,以>结尾的那部份,输出结果是:acsdcssdcd  
  18. 注意:上面的 .* 是表示任何字符,也就是说不管<>包住的是什么都去掉其中. 表示任意字符, * 表示任意个数  
  19.   
  20. 现在我们来改动一下,如果不想是任何个数呢?  
  21. $str="acsdcs<55555555>sc<6666>sdcd";  
  22. echo preg_replace("/<.{4}>/","",$str); //此时输出:acsdcs<55555555>scsdcd因为{4}指定了条件:<>内为4个字符的才满足条件,所以<55555555>不符合条件,没有被替换。  
  23.   
  24. 注意:这时我们又学到了一个知识点{数字} 表示指定前面的个数,*就表示是任意个(0--无限个)  
  25.   
  26. 表示重复次数的除了 *, {指定次数} 表示,还有很多表达形式:  
  27.   
  28.    
  29.   
  30. <?php  
  31. $str="acsdcs<55555555>sc<6666>sd<>cd";  
  32. echo preg_replace("/<[0-9]*>/","",$str);  
  33. //输出acsdcscd  
  34. echo "<hr>";  
  35. echo preg_replace("/<[0-9]+>/","",$str);  
  36. //输入acsdcsscsd<>cd  
  37. ?>  
  38.   
  39. 上面的例子只要是为了 表达 * 与+的区别 ,* 表示重复0数或n 次,而+ 表示1次以上,即一例中<[0-9]+ >表示<>里面至少要有一个数字才符合条件。  
  40.   
  41. 相信这时大家知道,为什么上例中用* 和用+输出的结果不同了吧  
  42.   
  43. 再来:  
  44.   
  45. <?php  
  46. $str="acsdcs<55555555>sc<6666>sd<>cd";  
  47. echo preg_replace("/<[0-9]?>/","",$str);  
  48. //输出acsdcs<55555555>sc<6666>sdcd  
  49. ?>  
  50.   
  51. 看[0-9]? 这里的?表示要是0次或1 次,超过1次又不符合条件了。  
  52. 总结一下,上面我们学会了 * + ? 和大括号{}表示重复次数的方法。  
  53.   
  54. ----------------------------------------------------------------------------------------------------  
  55.   
  56.     $s=preg_replace("/(.*?[月票|求|更].*?)/i","",$s);  
  57.     preg_match_all('/href=\"([0-9]+)\.shtm">(.+?)<\/a>/i',$s,$arr_dstorycate);      
  58.     print_r($arr_dstorycate);  
  59.   
  60. ----------------------------------------------------------------------------------------------------  
  61.   
  62.    preg_match_all("/<img.*?src=[\\\'| \\\"](.*?(?:[\.gif|\.jpg]))[\\\'|\\\"].*?[\/]?>/i",$content,$arr_dstorycate);              
  63.    print_r($arr_dstorycate);   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值