ホームページ > バックエンド開発 > PHPチュートリアル > 中国語のテキスト文字列を文字化けせずにインターセプトする PHP 方法_PHP チュートリアル

中国語のテキスト文字列を文字化けせずにインターセプトする PHP 方法_PHP チュートリアル

WBOY
リリース: 2016-07-13 10:48:36
オリジナル
869 人が閲覧しました

多くの PHP 初心者は、substr() 関数または mb_substr() 関数を使用して文字をインターセプトする必要があり、2 番目の文字は文字化けしません。以下に、文字列インターセプトを使用しない例をいくつかまとめます。文字化け。


例 1

コードは次のとおりです コードをコピー

関数 msubstr($str, $start=0, $length, $charset="utf-8", $suffix=true)
{
if(function_exists("mb_substr"))
return mb_substr($str, $start, $length, $charset);
elseif(function_exists('iconv_substr')) {
return 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."…";
$slice を返す;
}

例 2

コードは次のとおりです コードをコピー

//$start: 文字列をインターセプトする開始位置を指定します。$length はインターセプトされる文字の長さを指定します
関数 substr2($string, $start, $length)
{
$len = strlen($string);
if($len > $length)
{
$str = '';
$len1 = $start + $length //元の文字列の位置までインターセプトします
for($i=$start; $i {
If(ord(substr($string, $i, 2)) > 0xa0) //ASCII では、0xa0 は漢字の先頭を表します
{
$str.=substr($string, $i, 2);
$i++;
}
それ以外
{
$str.=substr($string, $i, 1);
}
}
$str を返します。'...';
}
それ以外
{
$string を返します;
}
}

?>

同じアイデアで簡単なものを追加(2010-5-31)

コードは次のとおりです コードをコピー

関数 chinesesubstr($str, $start, $len){
$strlen = $start + $len;
for($i=0; $i If(ord(substr($str, $i, 1)) > 0xa0){
$tmpstr .= substr($str, $i, 2);
$i++;
}その他{
$tmpstr .= substr($str, $i, 1);
}
}
$tmpstr;
を返します }
$str = "あなたを待っています、戻ってくるのを待っています";
echo chinesesubstr($str, 0, 19)
?>

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/632772.html技術記事多くの PHP 初心者は substr() 関数または mb_substr() 関数を使用して文字をインターセプトする必要があり、2 番目の文字はパフォーマンスが低下します...
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート