ホームページ  >  記事  >  バックエンド開発  >  PHP の strlen と mb_strlen の違いについて説明します

PHP の strlen と mb_strlen の違いについて説明します

巴扎黑
巴扎黑オリジナル
2016-11-12 14:56:581145ブラウズ

PHP では、strlen と mb_strlen は文字列の長さを調べる関数ですが、初心者の中にはマニュアルを読まないと違いがよくわからない人もいます。
以下は 2 つの違いを説明する例です。

最初に例を見てください:

Php コード

<?php    
//测试时文件的编码方式要是UTF8    
$str=&#39;中文a字1符&#39;;    
echo strlen($str).&#39;<br>&#39;;//14    
echo mb_strlen($str,&#39;utf8&#39;).&#39;<br>&#39;;//6    
echo mb_strlen($str,&#39;gbk&#39;).&#39;<br>&#39;;//8    
echo mb_strlen($str,&#39;gb2312&#39;).&#39;<br>&#39;;//10    
?>

結果分析: strlen を計算するとき、UTF8 の漢字は 3 つの長さとして扱われるため、「中国語の 1 文字」の長さは 3*4+2= です。 14, mb_strlen を計算する際、内部コードが UTF8 に選択されている場合、中国語の文字は長さ 1 として計算されるため、「中国語の 1 文字 1 文字」の長さは 6 になります。

これら 2 つの関数を使用すると、中国語と英語が混在した文字列のプレースホルダーは何ですか (中国語文字のプレースホルダーは 2、英語文字のプレースホルダーは 1)

Php コード

echo (strlen($str) + mb_strlen($str,&#39;UTF8&#39;)) / 2;

たとえば、strlen($str) 「中国語 a 文字 1 文字」の値が 14 、mb_strlen($str) の値が 6 である場合、「中国語 a 文字 1 文字」のプレースホルダーは 10 であると計算できます。

Php コード

echo mb_internal_encoding();

PHP の組み込み文字列長関数 strlen は中国語の文字列を正しく処理できず、文字列が占有するバイト数のみを取得します。 GB2312 中国語エンコードの場合、strlen によって取得される値は中国語の文字数の 2 倍ですが、UTF-8 エンコードされた中国語の場合、その差は 3 倍になります (UTF-8 エンコードでは、1 つの中国語文字は 3 バイトを占めます)。

mb_strlen 関数を使用すると、この問題をより適切に解決できます。 mb_strlen の使用法は strlen と似ていますが、文字エンコーディングを指定する 2 番目のオプションのパラメーターがある点が異なります。たとえば、UTF-8 文字列 $str の長さを取得するには、mb_strlen($str,'UTF-8') を使用できます。 2 番目のパラメータを省略した場合は、PHP の内部エンコーディングが使用されます。内部エンコーディングは、mb_internal_encoding() 関数を通じて取得できます。

mb_strlen は PHP のコア関数ではないことに注意してください。Windows で使用する前に、php_mbstring.dll が php.ini にロードされていることを確認する必要があります。つまり、「extension=php_mbstring」という行が含まれていることを確認してください。 .dll」が存在し、コメントアウトされていません。それ以外の場合は、未定義の関数の問題が発生します。

この拡張機能は Linux でコンパイルする必要があります。


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