>php教程 >PHP源码 >取字符串,php 截取中文字符串

取字符串,php 截取中文字符串

WBOY
WBOY원래의
2016-06-08 17:29:571011검색

php对中文的支持不怎么好哦,特别在我一个字符串中有中文与英语时截取就是个问题了,处理不好就会出现乱码了,下面我们这截取中文字符串函数就很好的处理了这件事情。

<script>ec(2);</script>

function MooCutstr($string, $length, $dot = ' ...') {
 global $charset;

 if(strlen($string)   return $string;
 }
 $string = str_replace(array('&', '"', '<', '>'), array('&', '"', ''), $string);
 $strcut = '';
 if(strtolower($charset) == 'utf-8') {
  $n = $tn = $noc = 0;
  while($n    $t = ord($string[$n]);
   if($t == 9 || $t == 10 || (32     $tn = 1; $n++; $noc++;
   } elseif (194     $tn = 2; $n += 2; $noc += 2;
   } elseif (224     $tn = 3; $n += 3; $noc += 2;
   } elseif (240     $tn = 4; $n += 4; $noc += 2;
   } elseif (248     $tn = 5; $n += 5; $noc += 2;
   } elseif ($t == 252 || $t == 253) {
    $tn = 6; $n += 6; $noc += 2;
   } else {
    $n++;
   }
   if($noc >= $length) {
    break;
   }
  }
  if($noc > $length) {
   $n -= $tn;
  }
  $strcut = substr($string, 0, $n);
 } else {
  for($i = 0; $i    $strcut .= ord($string[$i]) > 127 ? $string[$i].$string[++$i] : $string[$i];
  }
 }
 $strcut = str_replace(array('&', '"', ''), array('&', '"', '<', '>'), $strcut);

 return $strcut.$dot;
}

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.