我正在读取一个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|你知道如何从这样的数据中获得正确的积分吗?
发布于 2012-02-18 16:37:54
看起来您的字符串是以UTF-16编码的,而不是UTF-8。
要么更改获取数据的位置,要么转换编码:
$data[10] = iconv('UTF-16', 'UTF-8', $data[10])https://stackoverflow.com/questions/9339654
复制相似问题