找回密码
 注册

QQ登录

只需一步,快速开始

查看: 1121|回复: 1

具体讲解PHP导出Excel乱码的解决方法

k10911 发表于 2012-4-16 09:29:04 | 显示全部楼层 |阅读模式 来自 中国河南郑州

马上注册,结交更多好友,享用更多功能。

您需要 登录 才可以下载或查看,没有帐号?注册

x
我们在运用PHP语言进行Excel文件导出时可能会遇到乱码的问题,PHP导出Excel乱码具体的解决方法我们在文中做了详细的介绍,希望对大家有所帮助。
PHP导出Excel文件时有两个主要的过程:
1、定义文件名
2、填充Excel数据
这两个过程中可能会出现一些PHP导出Excel乱码问题,下面我来说一下解决办法:
解决文件名的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编码。
解决Excel内数据的PHP导出Excel乱码:
PHP导出Excel乱码原因:网页编码与Excel编码不一致。
解决办法:既然编码不一致,那让其一致了就OK了。定义Excel的字符集:header("Content-Type: application/vnd.ms-excel; charset=UTF-8"),看到charset=UTF-8了吧,让其与您网页编码一致即可解决Excel内数据乱码的问题了,这个比较简单!
成都电脑维修培训学校cdxcnote.soxsok.com/ 烟台挖掘机培训学校856.peixun360.com/青岛挖掘机培训529.peixun360.com/
坐而论道 发表于 2012-11-7 18:39:03 | 显示全部楼层 来自 中国广东深圳
看下,不是很懂
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表