php专区

 首页 > php专区 > PHP应用 > php函数大全 > php中文汉字字符串的截取问号 - php函数

php中文汉字字符串的截取问号 - php函数

分享到:
【字体:
导读:
          汉字中文使用php自带函数截取有时会碰到有问号了,下面我们整理了几个非常不错的汉字中文精确截取实例。php在操作字符串的问题时间无非两个...

php中文汉字字符串的截取问号

汉字中文使用php自带函数截取有时会碰到有问号了,下面我们整理了几个非常不错的汉字中文精确截取实例。

php在操作字符串的问题时间无非两个问题:

1.判断字符串编码是gbk还是unicode。

2.对相应编码采取相应截取方法。

一般情况下我们使用substr截取汉字可能会遇到乱码问题,因为汉字是双字节的,当被截取了一个字节时,这个汉字就无法显示,乱掉了。

其实解决很简单,看下面的截取函数,代码如下:

  1. //截取超长字符串 
  2. function curtStr($str,$len=30){ 
  3.  if(strlen($str)>$len){ 
  4.   $str = substr($str,0,$len); 
  5.   $str .= chr(0) ."…";  
  6.  return $str

上面的chr(0)不是null

null是什么都没有,而chr(0)的值是0。表示成16进制是0×00,表示成二进制是00000000

虽然chr(0)不会显示出什么,但是他是一个字符。

当汉字被截断时,根据编码规则他总是要把后边的其他字符拉过来一起作为汉字解释,这就是出现乱码的原因。而值为0×81到0xff与0×00组合始终都显示为“空”,根据这一特点,在substr的结果后面补上一个chr(0),就可以防止出现乱码了

下面补充几个函数即可实现此两点以达到精确截取中文字符串的目的,截取utf8编码的多字节字符串,代码如下:

  1.    //截取utf8字符串    
  2.    function utf8Substr($str$from$len)    
  3.    {    
  4.       return preg_replace('#^(?:[x00-x7F]|[xC0-xFF][x80-xBF]+){0,'.$from.'}'.    
  5.                          '((?:[x00-x7F]|[xC0-xFF][x80-xBF]+){0,'.$len.'}).*#s',    
  6.                          '$1',$str);    
  7.    }    
  8.    ?> 

UTF-8、GB2312都支持的汉字截取函数,代码如下:

  1.    /*    
  2.    Utf-8、gb2312都支持的汉字截取函数    
  3.    cut_str(字符串, 截取长度, 开始长度, 编码);    
  4.    编码默认为 utf-8    
  5.    开始长度默认为 0    
  6.    */     
  7.  
  8.    function cut_str($string$sublen$start = 0, $code = 'UTF-8')     
  9.   {     
  10.      if($code == 'UTF-8')     
  11.      {     
  12.          $pa = "/[x01-x7f]|[xc2-xdf][x80-xbf]|xe0[xa0-xbf][x80-xbf]|[xe1-xef][x80-xbf][x80-xbf]|xf0[x90-xbf][x80-xbf][x80-xbf]|[xf1-xf7][x80-xbf][x80-xbf][x80-xbf]/";     
  13.          preg_match_all($pa$string$t_string);     
  14.  
  15.          if(count($t_string[0]) - $start > $sublenreturn join(''array_slice($t_string[0], $start$sublen))."...";     
  16.          return join(''array_slice($t_string[0], $start$sublen));     
  17.      }     
  18.      else     
  19.      {     
  20.          $start = $start*2;     
  21.          $sublen = $sublen*2;     
  22.          $strlen = strlen($string);     
  23.          $tmpstr = '';     
  24.  
  25.         for($i=0; $i<$strlen$i++)     
  26.          {     
  27.              if($i>=$start && $i<($start+$sublen))     
  28.              {     
  29.                  if(ord(substr($string$i, 1))>129)     
  30.                  {     
  31.                      $tmpstr.= substr($string$i, 2);     
  32.                  }     
  33.                  else     
  34.                  {     
  35.                      $tmpstr.= substr($string$i, 1);     
  36.                  }     
  37.              }     
  38.              if(ord(substr($string$i, 1))>129) $i++;     
  39.          }     
  40.          if(strlen($tmpstr)<$strlen ) $tmpstr.= "...";     
  41.          return $tmpstr;     
  42.      }     
  43.   }     
  44.  
  45.   $str = "abcd需要截取的字符串";     
  46.   echo cut_str($str, 8, 0, 'gb2312');     
  47.   ?>
分享到:
php 打印出字符串的16进制 - php函数
php 打印出字符串的16进制 下面这个函数是一个php 打印出字符串的16进制实例,这里面的核心函数就是 chr获取二进制然后再进行转成16进制数,代码如下:  
php根据生日计算年龄/生肖/星座实例 - ph...
php根据生日计算年龄/生肖/星座实例 本文章来介绍根据用户出生年月来计算年龄/生肖/星座的各种程序实例代码,各位朋友不防进入参考. 计算年龄,代码如下: function birthday($mydate){       $birth=$mydate;       list($by,$bm,$bd)=explode(&#039;-&#039;,$birth);...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……