由于N久之前做了一些非常不好的动作导致网站内容页面有一些垃圾数据,今天早上整了一个移除字符串超链接文本方法,下面我结合正则来处理。
下面实例的功能是过滤所有的html标签,并替换h1-h5之前的所有文字,代码如下:
- 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'];
- 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;
- }
上面用到了下面的正则表达式,代码如下:
preg_replace("/(?is)(?<=<h1>).*?(?=</h1>)/i",$t);
这就是核心代码了,比如需要将文本中的超链接内容去除,这个时候就需要用到正则表达式了,比如你可以用$str = preg_replace("/<a[^>]*href=[^>]*>|</[^a]*a[^>]*>/i",$strhtml); 这段来实现需求,如果想要更多解决方法,可以参看以下的。
- ereg_replace('<a([^>]*)>([^<]*)</a>','<font color="red">2</font>',$content);
- ereg_replace("<a [^>]*>|</a>",$content);