如何使用索引逐个字符地迭代 UTF-8 字符串?
当您使用括号运算符 $str[0]
访问 UTF-8 字符串时,utf 编码的字符由 2 个或更多元素组成。
例如:
$str = "Kąt";
$str[0] = "K";
$str[1] = "�";
$str[2] = "�";
$str[3] = "t";
但我想要:
$str[0] = "K";
$str[1] = "ą";
$str[2] = "t";
mb_substr
是可能的,但这非常慢,即。
mb_substr($str, 0, 1) = "K"
mb_substr($str, 1, 1) = "ą"
mb_substr($str, 2, 1) = "t"
是否有另一种方法可以在不使用 mb_substr
的情况下逐个字符地对字符串进行交互?
最佳答案
使用preg_split .用"u" modifier它支持 UTF-8 unicode。
$chrArray = preg_split('//u', $str, -1, PREG_SPLIT_NO_EMPTY);
关于php - 如何在 PHP 中迭代 UTF-8 字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3666306/