這篇文章主要介紹了php無(wú)亂碼切割中文字符的方法,具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

在PHP中,substr()函數(shù)截取帶有中文字符串的話,可能會(huì)出現(xiàn)亂碼,這是因?yàn)橹形魑囊粋€(gè)字節(jié)所占有的字節(jié)數(shù)不一樣,而substr的長(zhǎng)度參數(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ò)展庫(kù)的mb_substr截取就不會(huì)出現(xiàn)亂碼了。
2、自己書(shū)寫(xiě)截取函數(shù),但效率不如用mbstring擴(kuò)展庫(kù)來(lái)得高。
3、如果僅是為了輸出截取的串,可用如下方式實(shí)現(xiàn):substr($str, 0, 30).chr(0)。
substr()函數(shù)可以分割文字,但要分割的文字如果包括中文字符往往會(huì)遇到問(wèn)題,這時(shí)可以用mb_substr()/mb_strcut這個(gè)函數(shù),mb_substr()/mb_strcut的用法與substr()相似,只是在mb_substr()/mb_strcut最后要加入多一個(gè)參數(shù),以設(shè)定字符串的編碼,但是一般的服務(wù)器都沒(méi)打開(kāi)php_mbstring.dll,需要在php.ini在把php_mbstring.dll打開(kāi)。
舉個(gè)例子:
<?php
echo mb_substr('這樣一來(lái)我的字符串就不會(huì)有亂碼^_^', 0, 7, 'utf-8');
?>
輸出:這樣一來(lái)我的字
<?php
echo mb_strcut('這樣一來(lái)我的字符串就不會(huì)有亂碼^_^', 0, 7, 'utf-8');
?>輸出:這樣一
從上面的例子可以看出,mb_substr是按字來(lái)切分字符,而mb_strcut是按字節(jié)來(lái)切分字符,但是都不會(huì)產(chǎn)生半個(gè)字符的現(xiàn)象。
PHP實(shí)現(xiàn)中文字串截取無(wú)亂碼的方法
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)中文字串截取無(wú)亂碼的方法--適用于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無(wú)亂碼切割中文字符的方法內(nèi)容對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,遇到問(wèn)題就找創(chuàng)新互聯(lián),詳細(xì)的解決方法等著你來(lái)學(xué)習(xí)!
文章標(biāo)題:php無(wú)亂碼切割中文字符的方法-創(chuàng)新互聯(lián)
文章鏈接:http://chinadenli.net/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)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容