PHP將HTML轉換成文本一些方法總結
來源:程序員人生 發布時間:2014-06-11 01:46:21 閱讀次數:3555次
在php中html轉換成文本提供了自帶的函數strip_tags了,但有時此函數不夠用,下面總結了一些用戶自定的函數,各位可參考.
最常用的使用php函數strip_tags,代碼如下:
- <?php
- $mystr=<<<SATO
- 此處省略幾十行HTML代碼^_^
- SATO;
- $str=strip_tags($mystr);
-
-
- ?>
自定義函數,代碼如下:
- <?php
-
-
-
-
- $search = array ("'<script[^>]*?>.*?</script>'si",
- "'<[/!]*?[^<>]*?>'si",
- "'([rn])[s]+'",
- "'&(quot|#34);'i",
- "'&(amp|#38);'i",
- "'&(lt|#60);'i",
- "'&(gt|#62);'i",
- "'&(nbsp|#160);'i",
- "'&(iexcl|#161);'i",
- "'&(cent|#162);'i",
- "'&(pound|#163);'i",
- "'&(copy|#169);'i",
- "'&#(d+);'e");
- $replace = array ("",
- "",
- "1",
- """,
- "&",
- "<",
- ">",
- " ",
- chr(161),
- chr(162),
- chr(163),
- chr(169),
- "chr(1)");
- $text = preg_replace ($search, $replace, $document);
- ?>
后來我從網上看到了一個使用PHP寫的方法,使用這個方法也可以實現將HTML轉為TXT文本,個人覺得也還蠻實用的,在這里分享一下,代碼如下:
- function HtmlToText($str){
- $str=preg_replace("/<sty(.*)/style>|<scr(.*)/script>|<!--(.*)-->/isU","",$str);
- $alltext="";
- $start=1;
- for($i=0;$i<strlen($str);$i++){
- if(($start==0)&&($str[$i]==">")){
- $start=1;
- }else if($start==1){
- if($str[$i]=="<"){
- $start=0;
- $alltext.="<font color='red'>|</font>";
- }else if(ord($str[$i])>31){
- $alltext.=$str[$i];
- }
- }
- }
-
- $alltext = str_replace(" "," ",$alltext);
- $alltext = preg_replace("/&([^;&]*)(;|&)/","",$alltext);
- $alltext = preg_replace("/[ ]+/s"," ",$alltext);
- return $alltext;
- }
使用下面這個方法也可以實現將簡答的HTML代碼轉換為TXT文本,實例代碼如下:
- function html2text($str,$encode = 'GB2312')
- {
- $str = preg_replace("/<style .*?</style>/is", "", $str);
- $str = preg_replace("/<script .*?</script>/is", "", $str);
- $str = preg_replace("/<br s*/?/>/i", "n", $str);
- $str = preg_replace("/</?p>/i", "nn", $str);
- $str = preg_replace("/</?td>/i", "n", $str);
- $str = preg_replace("/</?div>/i", "n", $str);
- $str = preg_replace("/</?blockquote>/i", "n", $str);
- $str = preg_replace("/</?li>/i", "n", $str);
- $str = preg_replace("/ /i", " ", $str);
- $str = preg_replace("/ /i", " ", $str);
- $str = preg_replace("/&/i", "&", $str);
- $str = preg_replace("/&/i", "&", $str);
- $str = preg_replace("/</i", "<", $str);
- $str = preg_replace("/</i", "<", $str);
- $str = preg_replace("/“/i", '"', $str);
- $str = preg_replace("/&ldquo/i", '"', $str);
- $str = preg_replace("/‘/i", "'", $str);
- $str = preg_replace("/&lsquo/i", "'", $str);
- $str = preg_replace("/’/i", "'", $str);
- $str = preg_replace("/&rsquo/i", "'", $str);
- $str = preg_replace("/>/i", ">", $str);
- $str = preg_replace("/>/i", ">", $str);
- $str = preg_replace("/”/i", '"', $str);
- $str = preg_replace("/&rdquo/i", '"', $str);
- $str = strip_tags($str);
- $str = html_entity_decode($str, ENT_QUOTES, $encode);
- $str = preg_replace("/&#.*?;/i", "", $str);
-
- return $str;
- }
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈