php导出excel乱码的解决办法:1、对【$filename】转码,执行语句【iconv('utf-8, gb2312, $filename)】;2、定义excel的字符集,网页编码一致与【charset=utf-8】一致。
php导出excel乱码的解决办法:
1、解决文件名的php导出excel乱码:
乱码原因:客户使用的中文版windows系统平台,而windows平台的文件名编码为gb2312(gbk),而我们网页编码为了跟进现存潮流 一般都采用utf-8(国际化)编码,这时当我们:header(content-disposition: inline; filename=/ . $filename . .xls/)时就会出现乱码,假如你的网页编码就是gb2312那就不用考虑编码问题了。
解决办法:对$filename转码,执行:iconv('utf-8, gb2312, $filename)。假如你的环境不支持iconv函数可以换别的函数,只要能将$filename的编码转为gbk就行。
但是这样问题又会来了,linux用户又会出现文件名乱码(因为linux平台文件名不是gbk编码)。
考虑到这个问题我采用两个办法:第一:放弃一部分客户,毕竟windows系统用户占绝大部分。第二:像gmail一样,提供两个下载地址。一个文件名gbk编码,一个文件名utf-8编码。
2、解决excel内数据的php导出excel乱码:
php导出excel乱码原因:网页编码与excel编码不一致。
解决办法:既然编码不一致,那让其一致了就ok了。定义excel的字符集:header(content-type: application/vnd.ms-excel; charset=utf-8),看到charset=utf-8了吧,让其与您网页编码一致即可解决excel内数据乱码的问题了,这个比较简单!
相关视频推荐:php编程从入门到精通
以上就是php导出excel乱码怎么办的详细内容。