A-A+
php使用正则表达式过滤删除标签内容
做项目的时候为了省劲,所以搞了好多的垃圾内容在数据库里面,而最近又要进行数据库的优化,所以索性将这些垃圾的内容给剔除掉,也就是将多余的URL给剔除掉,因为这些URL完全是可以写在网页里面的,而没必要插进mysql数据库。
好了,关于冗余的html标签,直接使用如下的代码:
- for( $i=1;$i<=5;$i++ )
- {
- $sql ="SELECT * FROM `表名` WHERE `字段` like '<h".$i.">%</h".$i.">%' ";
- $query = mysql_query( $sql ) or die(mysql_error());
- if( mysql_num_rows( $query ) )
- {
- while ( $rs = mysql_fetch_array( $query ) )
- {
- //print_r($rs);
- $t = stripslashes($rs['字段']);
- $str = nl2br(strip_tags(addslashes(removelink($t))));
- $sql ="update 表名 set 字段='$str' where id=".$rs['id'];
- //www.xiariboke.net
- if( mysql_query($sql))
- {
- echo $rs['id'].'成功<br />';
- }
- else
- {
- echo mysql_error();
- }
- }
- }
- else
- {
- echo '己更新过没有记录了'.$sql.'<br />';
- }
- }
- function removelink($t)
- {
- //$str = preg_replace("/<a[^>]*href=[^>]*>|</[^a]*a[^>]*>/i","",$t);
- $str = preg_replace("/(?is)(?<=<h1>).*?(?=</h1>)/i","",$t);
- $str = preg_replace("/(?is)(?<=<h2>).*?(?=</h2>)/i","",$str);
- $str = preg_replace("/(?is)(?<=<h3>).*?(?=</h3>)/i","",$str);
- $str = preg_replace("/(?is)(?<=<h4>).*?(?=</h4>)/i","",$str);
- $str = preg_replace("/(?is)(?<=<h5>).*?(?=</h5>)/i","",$str);
- return re_h($str);
- }
- function re_h($str)
- {
- $str = str_replace('<h1>','',$str);
- $str = str_replace('<h2>','',$str);
- $str = str_replace('<h3>','',$str);
- $str = str_replace('<h4>','',$str);
- $str = str_replace('<h5>','',$str);
- $str = str_replace('</h1>','',$str);
- $str = str_replace('</h2>','',$str);
- $str = str_replace('</h3>','',$str);
- $str = str_replace('</h4>','',$str);
- $str = str_replace('</h5>','',$str);
- return $str;
- }
这段代码是将 html 过滤掉,并直接替换成 h1 到 h5 的标签,如果你有这样的需求,可以自行更改一下,上面的代码用到的正则如下:
- preg_replace("/(?is)(?<=<h1>).*?(?=</h1>)/i","",$t);
这是过滤替换的核心代码了,我们稍加修改一下就可以改成为自己的需求代码,比如我们将文本中的 url 超链接去除掉的话,就可以使用如下代码:
- $str = preg_replace("/<a[^>]*href=[^>]*>|</[^a]*a[^>]*>/i","",$strhtml);
好了,关于更多的正则这里就不多说了,下面再给上两个常用的正则例子。
1、删除内容中的超链接,代码如下:
- ereg_replace('<a([^>]*)>([^<]*)</a>','<font color="red">\2</font>',$content);
- ereg_replace("<a [^>]*>|</a>","",$content);
2、消除包含特定词的超链接,代码如下:
- $find="this string is my find";
- $string='<font color="red">替换掉了</font>';//将超链接替换成的内容
- echo ereg_replace('<a([^>]*)>([^<]*'.$find.'[^>]*)</a>','<font color="red">\2</font>',$content);
在PHP中,结合正则表达式来过滤替换内容标签的实例有很多,应用也很广,这类代码不用死记硬背,需要的时候直接从网上搜索就可以了。