PHP 文字列インターセプト関数、strlen と mb_strlen の違い、PHP チュートリアルで文字列の長さを計算するための一般的な関数は次のとおりです:
strlen と mb_strlen は、すべて英字の場合は同じです。ここでは主に中国語と英語が混在した場合の 2 つの計算結果を比較します。
PHP では、strlen と mb_strlen は文字列の長さを調べる関数です。
両者の違い。
例:
結果分析: strlen を計算するとき、UTF8 の漢字は 3 文字として扱われるため、「中国語 1 文字」の長さは 3*4+2=14 になります。mb_strlen を計算するとき、選択された内部コードは UTF8 です。 , 漢字は1文字の長さとして計算されるので、「漢字1文字」の長さは6になります
これら 2 つの関数を使用すると、中国語と英語が混在した文字列の占有率を共同で計算できます (中国語の文字の占有率は 2、英語の文字の占有率は 1)
echo (strlen($str) + mb_strlen( $ str,'UTF8')) / 2;
たとえば、「中国語 1 文字 1 文字」の strlen($str) 値が 14、mb_strlen($str) 値が 6 の場合、「中国語」の値は1 文字 1 文字」を計算できます。プレースホルダーは 10 です。
echo mb_internal_encoding();
PHP の組み込み文字列長関数 strlen は、中国語の文字列を正しく処理できません。文字列が占有するバイト数を取得するだけです。 GB2312 中国語エンコードの場合、strlen によって取得される値は中国語の文字数の 2 倍ですが、UTF-8 エンコードされた中国語の場合、その差は 3 倍になります (UTF-8 エンコードでは、1 つの中国語文字は 3 バイトを占めます)。 www.jbxue.com
mb_strlen 関数を使用すると、この問題をより適切に解決できます。 mb_strlen の使用法は strlen と似ていますが、文字エンコーディングを指定する 2 番目のオプションのパラメーターがある点が異なります。たとえば、UTF-8 文字列 $str の長さを取得するには、mb_strlen($str,'UTF-8') を使用できます。 2 番目のパラメータを省略した場合は、PHP の内部エンコーディングが使用されます。内部エンコーディングは、mb_internal_encoding() 関数を通じて取得できます。
mb_strlen は PHP のコア関数ではないことに注意してください。これを使用する前に、php_mbstring.dll が php.ini にロードされていることを確認する必要があります。つまり、「extension=php_mbstring.dll」という行が含まれていることを確認してください。存在し、コメントアウトされていない場合は、関数の定義に関するエラー メッセージが表示されます。
strlen は文字列の長さを計算します。漢字 1 文字は 2 文字です。
mb_strlen は、文字エンコーディング モードに従って
count で指定された文字数をカウントし、配列内の要素の数またはオブジェクト内の属性の数を計算します
strlen と mb_strlen は文字列の長さを調べる関数です
以下は 2 つの違いを説明するための例です。
';//14echo mb_strlen($str, 'utf8' ).'
';//6echo mb_strlen($str,'gbk').'
';//8echo mb_strlen($str,'gb2312').'
';/ /10?> mb_strlen は PHP のコア関数ではないことに注意してください。これを使用する前に、php_mbstring.dll が php.ini にロードされていることを確認する必要があります。 「extension=php_mbstring.dll」が存在し、コメントアウトされていない場合、未定義の関数の問題が発生します。