xinpureZhu

Menu

PHP 导出 CSV 文件用 Excel 打开出现中文乱码

乱码情况

写了一段导出 CSV 文件的代码,可以正常输出

使用 CSVTXT 程序打开文件是正常的,但是使用 Excel 打开文件就出现了中文乱码的问题(这就奇怪了, 为什么在 Excel 中会乱码呢?)

通过查看编码发现,导出的 CSV 文件是 UTF-8 无BOM编码格式,而我们通常使用 UTF-8 编码格式 都是有 BOM 的。

尝试着添加了 BOM 之后,中文乱码的问题有解决了。

添加 BOM 到 CSV 文件中

示例代码:

$file = fopen($export_file_path, 'w');

fwrite($file, chr(0xEF).chr(0xBB).chr(0xBF)); // 添加 BOM

foreach ($contens as $content) {
        fputcsv($file, $content);
}
fclose($file);
— 于 共写了342个字
— 文内使用到的标签:

一条回应:“PHP 导出 CSV 文件用 Excel 打开出现中文乱码”

  1. 烤红薯说道:

    谢谢博主。你的博客简介明了,又非常有用。

发表评论

电子邮件地址不会被公开。 必填项已用*标注