php - 使用 fgetcsv 读取 CSV 文件时出现 UTF-8 问题

标签 php csv utf-8 fgetcsv

我尝试读取 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/

相关文章:

php - 如何修改 WooCommerce 中的商店页面主查询以显示列表中每个产品的变体?

php - 带有 wp_remote_post 的 google url 缩短 API

csv - Access VBA 将 CSV 文件导出为 UTF-8

mysql - 使用 Windows 换行符作为分隔符的 CSV

php - 在 PHP 中模拟一个简单的 "warning"

php日期格式

python - 如何将键值管道分隔文件转换为带标题的完美 csv 文件

HTML 输入框中的 PHP UTF-8 编码

php - 马拉雅拉姆语字体字符作为未知字符保存到mysql数据库中

mysql - 查询 mysql DB 时 Rails 4 中的编码错误