這篇文章主要介紹了php無亂碼切割中文字符的方法,具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。
在PHP中,substr()函數(shù)截取帶有中文字符串的話,可能會(huì)出現(xiàn)亂碼,這是因?yàn)橹形魑囊粋€(gè)字節(jié)所占有的字節(jié)數(shù)不一樣,而substr的長度參數(shù)是按照字節(jié)去算的,在GB2312編碼時(shí),一個(gè)中文占2個(gè)字節(jié),英文為1個(gè)字節(jié),而在UTF-8編碼當(dāng)中,一個(gè)中文可能占有2個(gè)或3個(gè)字節(jié),英文或半角標(biāo)點(diǎn)占1字節(jié)。
直接使用PHP函數(shù)substr截取中文字符可能會(huì)出現(xiàn)亂碼,主要是substr可能硬生生的將一個(gè)中文字符“鋸”成兩半。解決辦法:
1、使用mbstring擴(kuò)展庫的mb_substr截取就不會(huì)出現(xiàn)亂碼了。
2、自己書寫截取函數(shù),但效率不如用mbstring擴(kuò)展庫來得高。
3、如果僅是為了輸出截取的串,可用如下方式實(shí)現(xiàn):substr($str, 0, 30).chr(0)。
substr()
函數(shù)可以分割文字,但要分割的文字如果包括中文字符往往會(huì)遇到問題,這時(shí)可以用mb_substr()
/mb_strcut
這個(gè)函數(shù),mb_substr()/mb_strcut的用法與substr()相似,只是在mb_substr()/mb_strcut最后要加入多一個(gè)參數(shù),以設(shè)定字符串的編碼,但是一般的服務(wù)器都沒打開php_mbstring.dll
,需要在php.ini在把php_mbstring.dll打開。
舉個(gè)例子:
<?php echo mb_substr('這樣一來我的字符串就不會(huì)有亂碼^_^', 0, 7, 'utf-8'); ?> 輸出:這樣一來我的字 <?php echo mb_strcut('這樣一來我的字符串就不會(huì)有亂碼^_^', 0, 7, 'utf-8'); ?>
輸出:這樣一
從上面的例子可以看出,mb_substr是按字來切分字符,而mb_strcut是按字節(jié)來切分字符,但是都不會(huì)產(chǎn)生半個(gè)字符的現(xiàn)象。
PHP實(shí)現(xiàn)中文字串截取無亂碼的方法
function GBsubstr($string, $start, $length) { if(strlen($string)>$length){ $str=null; $len=$start+$length; for($i=$start;$i<$len;$i++){ if(ord(substr($string,$i,1))>0xa0){ $str.=substr($string,$i,2); $i++; }else{ $str.=substr($string,$i,1); } } return $str.'...'; }else{ return $string; } }
實(shí)現(xiàn)中文字串截取無亂碼的方法--適用于utf-8
function substr_text($str, $start=0, $length, $charset="utf-8", $suffix="") { if(function_exists("mb_substr")){ return mb_substr($str, $start, $length, $charset).$suffix; } elseif(function_exists('iconv_substr')){ return iconv_substr($str,$start,$length,$charset).$suffix; } $re['utf-8'] = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|[\xe0-\xef][\x80-\xbf]{2}|[\xf0-\xff][\x80-\xbf]{3}/"; $re['gb2312'] = "/[\x01-\x7f]|[\xb0-\xf7][\xa0-\xfe]/"; $re['gbk'] = "/[\x01-\x7f]|[\x81-\xfe][\x40-\xfe]/"; $re['big5'] = "/[\x01-\x7f]|[\x81-\xfe]([\x40-\x7e]|\xa1-\xfe])/"; preg_match_all($re[$charset], $str, $match); $slice = join("",array_slice($match[0], $start, $length)); return $slice.$suffix; }
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享php無亂碼切割中文字符的方法內(nèi)容對大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,遇到問題就找創(chuàng)新互聯(lián),詳細(xì)的解決方法等著你來學(xué)習(xí)!
文章標(biāo)題:php無亂碼切割中文字符的方法-創(chuàng)新互聯(lián)
文章鏈接:http://jinyejixie.com/article0/dphpoo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護(hù)、App設(shè)計(jì)、網(wǎng)站設(shè)計(jì)公司、外貿(mào)建站、ChatGPT、建站公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容