当前位置:首页 > PHP教程 > php函数 > 列表

php字符串截取,支持中文和其他编码

发布:smiling 来源: PHP粉丝网  添加日期:2014-08-28 17:01:28 浏览: 评论:0 

本文章总结了在php函数substr的基础上来截取字符串的函数,在碰到中文时出现汉字截取一半出现乱码的解决办法了,下面介绍了支持中文和其他编码截取程序.

php代码如下:

  1. <?php 
  2.  
  3. /** 
  4.  * 字符串截取,支持中文和其他编码 
  5.  * 
  6.  * @static 
  7.  * @access public 
  8.  * @param string $str 需要转换的字符串 
  9.  * @param string $start 开始位置 
  10.  * @param string $length 截取长度 
  11.  * @param string $charset 编码格式 
  12.  * @param string $suffix 截断显示字符 
  13.  * @return string 
  14.  */ 
  15. function msubstr($str$start=0, $length$charset="utf-8"$suffix=true) 
  16.     if(function_exists("mb_substr")) 
  17.          mb_substr($str$start$length$charset); 
  18.     elseif(function_exists('iconv_substr')) { 
  19.          iconv_substr($str,$start,$length,$charset); 
  20.     } 
  21.     $re['utf-8']   = "/[x01-x7f]|[xc2-xdf][x80-xbf]|[xe0-xef][x80-xbf]{2}|[xf0-xff][x80-xbf]{3}/"
  22.     $re['gb2312'] = "/[x01-x7f]|[xb0-xf7][xa0-xfe]/"
  23.     $re['gbk']    = "/[x01-x7f]|[x81-xfe][x40-xfe]/"
  24.     $re['big5']   = "/[x01-x7f]|[x81-xfe]([x40-x7e]|xa1-xfe])/"
  25.     preg_match_all($re[$charset], $str$match); 
  26.     $slice = join("",array_slice($match[0], $start$length)); 
  27.     if($suffixreturn $slice."…"
  28.     return $slice
  29. ?> 

如果我们直接使用了php substr来截取数据如在英文和汉字混合的情况下会出现如下问题,如果有这样一个字符串:

$str="这是一个字符串"; 

为了截取该串的前10个字符,使用:

if(strlen($str)>10) $str=substr($str,10)."…"; 

那么,echo $str的输出应该是"这是一个字…"

假设: $str="这是1个字符串";这个串中包含了一个半角字符,同样执行:

if(strlen($str)>10) $str=substr($str,10); 

由于原字符串$str的第10、11个字符构成了汉字“符”;执行串分割后会将该汉字一分为二,这样被截取的串就会发现乱码现象,使用了上面这代码字符截取代码就可以方便的解决了这种问题了.

今天找到一个比较好的截取中文字符串方法,在此与大家共享,代码如下:

  1. function msubstr($str$start$len) { 
  2.     $tmpstr = ""
  3.     $strlen = $start + $len
  4.     for($i = 0; $i < $strlen$i++) { 
  5.         if(ord(substr($str$i, 1)) > 0xa0) { 
  6.             $tmpstr .= substr($str$i, 2); 
  7.             $i++; 
  8.         } else 
  9.             $tmpstr .= substr($str$i, 1); 
  10.     } 
  11.     return $tmpstr

程序二:PHP截取UTF-8字符串,解决半字符问题.

  1. /****************************************************************** 
  2. * PHP截取UTF-8字符串,解决半字符问题。 
  3. * 英文、数字(半角)为1字节(8位),中文(全角)为3字节 
  4. * @return 取出的字符串, 当$len小于等于0时, 会返回整个字符串 
  5. * @param $str 源字符串 
  6. * $len 左边的子串的长度 
  7. ****************************************************************/ 
  8.  
  9. function utf_substr($str,$len
  10. for($i=0;$i<$len;$i++) 
  11. $temp_str=substr($str,0,1); 
  12. if(ord($temp_str) > 127) 
  13. $i++; 
  14. if($i<$len
  15. $new_str[]=substr($str,0,3); 
  16. $str=substr($str,3); 
  17. }//开源代码phpfensi.com 
  18. else 
  19. $new_str[]=substr($str,0,1); 
  20. $str=substr($str,1); 
  21. return join($new_str); 

Tags: php字符串截取 php中文截取

分享到: