PHP中substr截取中文乱码解决方案
生活随笔
收集整理的這篇文章主要介紹了
PHP中substr截取中文乱码解决方案
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
在PHP中經常使用substr來進行字符串的截取,但是當我們用它來實現對中文字符進行截取的時候則會發生亂碼問題,比如說:
<?php $mystring="今天天氣真好"; $mysubstring=substr($mystring,0,2); echo $mysubstring; ?> 輸出結果為�;原因分析: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中substr截取中文乱码解决方案的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php在函数内使用全局变量
- 下一篇: printf与sprintf