我正在读取一个UTF8文件,并将从文件中读取的数据存储在一个数组中。但是,在mysql查询中使用该数据时,我遇到了问题。 我以为我会在使用之前使用intval(..)显式转换所有int值。但是intval(utf8string)给了我零。
以下代码提供了意外的输出:
//.....
var_dump($data[10]);
echo '|' . $data[10] . "|\n";
echo '|' . bin2hex($data[10]) . "|\n";
echo '|' . utf8_decode($data[10]) . "|\n";
echo '|' . intval(utf8_decode($data[10])) . "|\n";
echo '|' . intval($data[10]). "|\n"; exit
//.....
输出:
string(15) "2240000"
|2240000|
|003200320034003000300030003000|
|2240000|
|0|
|0|
知道如何从这些数据中获取正确的intval吗?
答案 0 :(得分:1)
您的字符串看起来是用 UTF-16 编码的,而不是UTF-8。
要么改变从中获取数据的位置,要么转换编码:
$data[10] = iconv('UTF-16', 'UTF-8', $data[10])