gpt4 book ai didi

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

转载 作者:IT王子 更新时间:2023-10-29 01:09:40 24 4
gpt4 key购买 nike

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

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com