ホームページ >バックエンド開発 >PHPチュートリアル >中国語文字列の長さを計算し、中国語文字列をインターセプトする PHP 関数

中国語文字列の長さを計算し、中国語文字列をインターセプトする PHP 関数

WBOY
WBOYオリジナル
2016-07-25 09:04:17873ブラウズ
  1. header('Content-type:text/html;charset=utf-8');
  2. /**
  3. * 中国語の文字列の長さをカウントする関数
  4. * @param $str 長さを計算する文字列
  5. * @param $type 計算の長さのタイプ、0 (デフォルト) は 1 つの中国語文字を 1 文字としてカウントすることを意味し、1 は 1 つの中国語文字を意味します文字は 2 文字としてカウントされます
  6. * @http://bbs.it-home.org
  7. *
  8. */
  9. function abslength($str)
  10. {
  11. if( empty($str)){
  12. return 0;
  13. }
  14. if(function_exists('mb_strlen')){
  15. return mb_strlen($str,'utf-8');
  16. }
  17. else {
  18. preg_match_all("/./ u", $str, $ar);
  19. return count($ar[0]);
  20. }
  21. }
  22. $str = 'スクリプト アカデミーは皆さんを歓迎します! ';
  23. $len = abslength($str);
  24. var_dump($len); //return 12
  25. $len = abslength($str,'1');
  26. echo '
    '.$len ; //中国語の文字列をインターセプトするための 22
  27. /*
  28. utf-8 エンコーディングを返します。パラメーターは substr 関数を参照できます
  29. @param $str インターセプトされる文字列
  30. @param $start インターセプトされる開始位置、負の数値インターセプトする長さ
  31. @param $end インターセプトする長さ
  32. */
  33. function utf8_substr($str,$start=0) {
  34. if(empty($str)){
  35. return false;
  36. }
  37. if (function_exists (' mb_substr')){
  38. if(func_num_args() >= 3) {
  39. $end = func_get_arg(2);
  40. return mb_substr($str,$start,$end,'utf-8');
  41. }
  42. else {
  43. mb_internal_encoding("UTF-8");
  44. return mb_substr($str,$start);
  45. }
  46. }
  47. else {
  48. $null = "";
  49. preg_match_all("/./u", $str , $ ar);
  50. if(func_num_args() >= 3) {
  51. $end = func_get_arg(2);
  52. return join($null, array_slice($ar[0],$start,$end));
  53. }
  54. else {
  55. return join($null, array_slice($ar[0],$start));
  56. }
  57. }
  58. }
  59. $str2 = '中文を傍受したい';
  60. echo '
    echo utf8_substr($str2,0,-4); //zhon をインターセプトしますか?>
コードをコピーします
2 gb2312、gbk、utf-8、big5 中国語インターセプトをサポートします。方法

  1. /*
  2. * 中国語インターセプト、gb2312、gbk、utf-8、big5 をサポート
  3. * bbs.it-home.org
  4. * @param string $str インターセプトされる文字列
  5. * @param int $start インターセプト開始位置
  6. * @param int $length インターセプト長
  7. * @param string $charset utf-8|gb2312|gbk|big5 エンコード
  8. * @param $suffix サフィックスを追加するかどうか
  9. */
  10. public function csubstr($str, $start=0, $length, $charset="utf-8", $suffix=true)
  11. {
  12. if(function_exists("mb_substr"))
  13. {
  14. if(mb_strlen($str) , $charset) <= $length) return $str;
  15. $slice = mb_substr($str, $start, $length, $charset);
  16. }
  17. else
  18. {
  19. $re['utf-8'] = "/[x01-x7f]|[xc2-xdf][x80-xbf]|[xe0-xef][x80-xbf]{2}|[xf0-xff][x80-xbf]{3}/";
  20. $re['gb2312'] = "/[x01-x7f]|[xb0-xf7][xa0-xfe]/";
  21. $re['gbk'] = "/[x01-x7f]|[x81-xfe] ][x40-xfe]/";
  22. $re['big5'] = "/[x01-x7f]|[x81-xfe]([x40-x7e]|xa1-xfe])/";
  23. preg_match_all($ re[$charset], $str, $match);
  24. if(count($match[0]) <= $length) return $str;
  25. $slice = join("",array_slice($match[0]) , $start, $length));
  26. }
  27. if($suffix) return $slice."…";
  28. return $slice;
  29. }
  30. ?>
コードをコピー

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。