function moss_truncate($str, $cut) {
$len = strlen($str);
$count = 0; // count
$i = 0; // cut index
if($len < $cut)
return $str;
do {
if($count >= $cut)
return substr($str, 0, $i) . '...';
$value = ord($str[$i]); // ASCII value
if($value > 191 and $value < 224) // 2 bytes
$i+=2;
elseif($value > 223 and $value < 240) // 3 byte
$i+=3;
elseif($value > 239 and $value < 248) // 4 bytes
$i+=3;
else // others, include ASCII (less than 128)
$i++;
$count++;
} while($i < $len);
return $str;
}
$str = '蘑d,プリプリで美味';
echo moss_truncate($str, 8); //取8個"字", 不管是ASCII還是Unicode都算一個字
// 結果:
// 蘑d,プリプリで
參考:
解決中文字串的斷字問題?
PHP如何判斷是否為utf8編碼文件的方法
 
2 則留言:
其實PHP早就有處理Multibyte String的函式了(mb_開頭的)!
這個還是可以用來算Unicode字數~
其他方法參考: PHP 將 UTF-8 的 字串 依 指定長度 切割成陣列(str_split 的 UTF-8版) (Tsung's Blog)
張貼留言