php中文截取无乱码函数

php中文截取无乱码函数

内容导读

收集整理的这篇技术教程文章主要介绍了php中文截取无乱码函数,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1165字,纯文字阅读大概需要2分钟

内容图文

在PHP中经常使用substr来进行字符串的截取,但是当我们用它来实现对中文字符进行截取的时候则会发生乱码问题,比如说:

<?php$mystring="今天天气真好";$mysubstring=substr($mystring,0,2);echo $mysubstring;?>

输出结果为?;(推荐学习:PHP编程从入门到精通)

原因分析:substr函数原型为:string substr ( string $string , int $start [, int $length ] ),其中$length表示返回字节长度,而一个中文占两个字节,对于一个UTF-8的中文字符,会把它当做3个字节来处理。

<?php$length=strlen($mystring);echo $length;//
输出结果为18?>

就是说我们可以用令$length为3,这样就会成功返回一个“今”字。这样的话如果中文和英文混杂的话则需要我们好好地计算一下$length了。

那么有更好的解决办法吗?Php给出了另外的函数mb_strlen和mb_substr

<?php$length=mb_strlen($mystring);$mysub=mb_substr($mystring,0,4);echo "the length is:$length,","the substr is:$mysub";?>

输出结果为:the length is:6,the substr is:今天天气

mb_strlen函数原型为int mb_strlen(string string_input, string encode);encode默认为UTF-8,它会将为UTF-8编码的中文字符算作一个

注意:mb_strlen与mb_substr并不是PHP的核心函数,使用前需要打开php.ini中的extension=php_mbstring.dll这一项

以上就是php中文截取无乱码函数的详细内容,更多请关注Gxl网其它相关文章!

内容总结

以上是为您收集整理的php中文截取无乱码函数全部内容,希望文章能够帮你解决php中文截取无乱码函数所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。


本文关键词:

联系我们

在线咨询:点击这里给我发消息

邮件:w420220301@qq.com