我尝试读取 CSV 并回显内容。但内容显示字符错误。
Mäx Müstermänn -> Mäx Müstermänn
CSV 文件的编码是没有 BOM 的 UTF-8(使用 Notepad++ 检查)。
这是 CSV 文件的内容:
"Mäx";"Müstermänn"
我的 PHP 脚本
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<?php
$handle = fopen ("specialchars.csv","r");
echo '<table border="1"><tr><td>First name</td><td>Last name</td></tr><tr>';
while ($data = fgetcsv ($handle, 1000, ";")) {
$num = count ($data);
for ($c=0; $c < $num; $c++) {
// output data
echo "<td>$data[$c]</td>";
}
echo "</tr><tr>";
}
?>
</body>
</html>
我尝试按照建议使用 setlocale(LC_ALL, 'de_DE.utf8');
here没有成功。内容仍然显示错误。
我错过了什么?
编辑:
一个 echo mb_detect_encoding($data[$c],'UTF-8');
给我 UTF-8 UTF-8。
echo file_get_contents("specialchars.csv");
给我 "Mäx";"Müstermänn"
。
和
print_r(str_getcsv(reset(explode("\n", file_get_contents("specialchars.csv"))), ';'))
给我
数组 ( [0] => Mäx [1] => Müstermänn )
什么意思?
最佳答案
试试这个:
<?php
$handle = fopen ("specialchars.csv","r");
echo '<table border="1"><tr><td>First name</td><td>Last name</td></tr><tr>';
while ($data = fgetcsv ($handle, 1000, ";")) {
$data = array_map("utf8_encode", $data); //added
$num = count ($data);
for ($c=0; $c < $num; $c++) {
// output data
echo "<td>$data[$c]</td>";
}
echo "</tr><tr>";
}
?>
关于php - 使用 fgetcsv 读取 CSV 文件时出现 UTF-8 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8882090/