首页 >后端开发 >PHP问题 >mac php导出excel乱码怎么办

mac php导出excel乱码怎么办

藏色散人
藏色散人原创
2021-07-26 09:50:102681浏览

mac php导出excel乱码的解决办法:首先打开相应的PHP文件;然后设置“header('Content-Type: application/vnd.ms-excel; charset=gb18030');”即可。

mac php导出excel乱码怎么办

本文操作环境:macOS10.15系统、PHP7.1版,MacBook Air 2019电脑

mac php导出excel乱码怎么办?

(PHP)修复mac book 导出 csv xls xlsx 中文乱码问题

背景:一般情况下,当我们导出 csv (或xls或xlsx)时,都需要通过文件头来设置一下文件输出的文字编码:

header('Content-Type: application/vnd.ms-excel; charset=utf8');

使用utf8编码的话,一般来说wps好使,office 就不太好使(office打开会乱码);

然后在很久很久的一段时间里,我都是使用 gbk 或 gb2312 来解决这个问题:

header('Content-Type: application/vnd.ms-excel; charset=gbk');

今天才发现,在mac book 环境下,设置 gbk 编码其实是不行的。也会乱码。经过百度一下之后,才知道要设置为 gb18030

header('Content-Type: application/vnd.ms-excel; charset=gb18030');

关于gb18030的介绍看这里:https://baike.baidu.com/item/gb18030/3204518


当然,除了修改文件头,还要记得修改 echo 出来的内容的编码,例如输出标题:

echo mb_convert_encoding(implode(',', array_values($titles)), 'gb18030') . "\n";

 修改后的导出类:

https://www.cnblogs.com/tujia/p/11358096.html


完。

推荐学习:《PHP视频教程

以上是mac php导出excel乱码怎么办的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn