PHP支援多種檔案編碼的中文字元截取函數

PHP中文网
發布: 2016-07-29 09:12:47
原創
1193 人瀏覽過

透過使用多種方法來實現中文字串的完美截取,在未安裝mbstring 和iconv擴充情況下支援UTF-8、GBK、GB2312、BIG5編碼,安裝上述擴充功能後支援的編碼更多,詳細情況參考函數說明。
共有三種方法 
1、mb_substr() 需要mbstring 擴充 
2、iconv_substr() 需要iconv擴充 
3、正規匹配,預設支援 
三種方法優先順序從上一個方法順序上不可用則自動順序使用下一種方法。

本程式碼從Midnight 發佈的"字串截取, 支援常用編碼" 程式碼最佳化而來

1.修正原程式碼中對mb_substr 和iconv_substr 沒有進行return ,所以相當於無效呼叫
2.優化截取字串後綴,可以自訂後綴。預設為空。

<?php
/**
 * 字符串截取,支持中文和其他编码
 *
 * @param string $str 需要转换的字符串
 * @param string $start 开始位置
 * @param string $length 截取长度
 * @param string $charset 编码格式
 * @param string $suffix 截断字符串后缀
 * @return string
 */
function substr_ext($str, $start=0, $length, $charset="utf-8", $suffix="")
{
    if(function_exists("mb_substr")){
         return mb_substr($str, $start, $length, $charset).$suffix;
    }
    elseif(function_exists(&#39;iconv_substr&#39;)){
         return iconv_substr($str,$start,$length,$charset).$suffix;
    }
    $re[&#39;utf-8&#39;]  = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|[\xe0-\xef][\x80-\xbf]{2}|[\xf0-\xff][\x80-\xbf]{3}/";
    $re[&#39;gb2312&#39;] = "/[\x01-\x7f]|[\xb0-\xf7][\xa0-\xfe]/";
    $re[&#39;gbk&#39;]    = "/[\x01-\x7f]|[\x81-\xfe][\x40-\xfe]/";
    $re[&#39;big5&#39;]   = "/[\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;
}
登入後複製


相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板