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.com
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中,结合正则表达式来过滤替换内容标签的实例有很多,应用也很广,这类代码不用死记硬背,需要的时候直接从网上搜索就可以了。

内容出处:,

声明:本网站所收集的部分公开资料来源于互联网,转载的目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。如果您发现网站上有侵犯您的知识产权的作品,请与我们取得联系,我们会及时修改或删除。文章链接:http://www.yixao.com/procedure/1315.html

发表评论

登录后才能评论