>  기사  >  백엔드 개발  >  PHP 汉字截取字符串出现了问题!!大神快来啊!!!!!

PHP 汉字截取字符串出现了问题!!大神快来啊!!!!!

WBOY
WBOY원래의
2016-06-06 20:41:12946검색

<code><br>$a='王多多';



echo mb_substr($a,0,2);

exit;


?>


</code>

按理说应该出现王多两个字,为什么出现了
我擦。。大神,这是为啥呢??????

回复内容:

<code><br>$a='王多多';



echo mb_substr($a,0,2);

exit;


?>


</code>

按理说应该出现王多两个字,为什么出现了
我擦。。大神,这是为啥呢??????

mb_substr指定编码即可解决。在线运行结果:http://3v4l.org/OsNXf

应该是PHP版本BUG吧,我看 对于没有指定编码的字符串,mb_substr是使用PHP默认编码进行处理的,对比各个版本的默认编码你会发现5.6以下都是ISO-8859-1,而只有5.6以上才是UTF-8(感谢 @kankana 的纠正)。 所以在5.6以上是没有问题的,可查看在线运行结果:http://3v4l.org/dFDgs

<code>mb_substr($a,0,2,'utf8')
</code>

根据:http://php.net/manual/zh/function.mb-substr.php

因为一个汉字占3个字节?
假如截取2的话,只是截取两个字符(一个字符一个字节)。

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