程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php字符串截取,支持中文和其他編碼

php字符串截取,支持中文和其他編碼

編輯:關於PHP編程

本文章總結了在php函數substr的基礎上來截取字符串的函數,但在碰到中文時出現漢字截取一半出現亂碼的解決辦法了,下面介紹了支持中文和其他編碼截取程序。  代碼如下 復制代碼

<?

/**
 * 字符串截取,支持中文和其他編碼
 *
 * @static
 * @access public
 * @param string $str 需要轉換的字符串
 * @param string $start 開始位置
 * @param string $length 截取長度
 * @param string $charset 編碼格式
 * @param string $suffix 截斷顯示字符
 * @return string
 */
function msubstr($str, $start=0, $length, $charset="utf-8", $suffix=true)
{
    if(function_exists("mb_substr"))
         mb_substr($str, $start, $length, $charset);
    elseif(function_exists('iconv_substr')) {
         iconv_substr($str,$start,$length,$charset);
    }
    $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));
    if($suffix) return $slice."…";
    return $slice;
}

如果我們直接使用了php substr來截取數據如

在英文和漢字混合的情況下會出現如下問題:

如果有這樣一個字符串
$str="這是一個字符串";
為了截取該串的前10個字符,使用
if(strlen($str)>10) $str=substr($str,10)."…";
那麼,echo $str的輸出應該是"這是一個字…"

假設
$str="這是1個字符串";
這個串中包含了一個半角字符,同樣執行:
if(strlen($str)>10) $str=substr($str,10);
由於原字符串$str的第10、11個字符構成了漢字“符”;
執行串分割後會將該漢字一分為二,這樣被截取的串就會發現亂碼現象

使用了上面這代碼字符截取代碼就可以方便的解決了這種問題了。

今天找到一個比較好的截取中文字符串方法,在此與大家共享。

 代碼如下 復制代碼

function msubstr($str, $start, $len) {
    $tmpstr = "";
    $strlen = $start + $len;
    for($i = 0; $i < $strlen; $i++) {
        if(ord(substr($str, $i, 1)) > 0xa0) {
            $tmpstr .= substr($str, $i, 2);
            $i++;
        } else
            $tmpstr .= substr($str, $i, 1);
    }
    return $tmpstr;
}

程序二:PHP截取UTF-8字符串,解決半字符問題

/******************************************************************
* PHP截取UTF-8字符串,解決半字符問題。
* 英文、數字(半角)為1字節(8位),中文(全角)為3字節
* @return 取出的字符串, 當$len小於等於0時, 會返回整個字符串
* @param $str 源字符串
* $len 左邊的子串的長度
****************************************************************/

 代碼如下 復制代碼 function utf_substr($str,$len)
{
for($i=0;$i<$len;$i++)
{
$temp_str=substr($str,0,1);
if(ord($temp_str) > 127)
{
$i++;
if($i<$len)
{
$new_str[]=substr($str,0,3);
$str=substr($str,3);
}
}
else
{
$new_str[]=substr($str,0,1);
$str=substr($str,1);
}
}
return join($new_str);
}
?>

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved