php strlen 计算汉字

在 PHP 中,strlen() 函数默认将字符串看作是字节序列,并且按字节来计算字符串的长度。对于单字节编码(如 ASCII 编码),strlen() 函数可以正确计算字符串的长度。然而,对于多字节字符(如汉字),每个字符由多个字节组成,使用 strlen() 函数会导致计算不准确。

如果您要计算字符串中的汉字个数,不应使用 strlen() 函数,而应使用 mb_strlen() 函数。mb_strlen() 函数考虑了字符编码,并正确计算字符串的字符个数。

以下是使用 mb_strlen() 函数计算汉字个数的示例:

$str = "你好,世界!";
$count = mb_strlen($str, 'UTF-8'); // 使用 UTF-8 编码计算汉字个数
echo "汉字个数为: $count";

这将输出:汉字个数为: 4

在上述示例中,我们使用 UTF-8 编码计算汉字个数,这是常见的字符编码。如果您使用其他字符编码(如 GBK),请将第二个参数 'UTF-8' 替换为相应的编码。

通过使用 mb_strlen() 函数,就可以准确计算字符串中的汉字个数,而不受多字节字符的影响。

猜你喜欢

转载自blog.csdn.net/qq_27487739/article/details/134592973