1、定义文件名
2、填充Excel数据
这两个过程中可能会出现一些PHP导出Excel乱码问题,下面我来说一下解决办法:
解决Excel内数据的PHP导出Excel乱码:
PHP导出Excel乱码原因:网页编码与Excel编码不一致。
解决办法:既然编码不一致,那让其一致了就OK了。定义Excel的字符集:
代码如下 | 复制代码 |
header(“Content-Type: application/vnd.ms-excel; charset=UTF-8″) |
,看到charset=UTF-8了吧,让其与您网页编码一致即可解决Excel内数据乱码的问题了,这个比较简单!
附一个php导出Excel类
代码如下 | 复制代码 | ||||||||
/*
|
总结
导出之前需要转换为GBK
代码如下 | 复制代码 |
iconv("UTF-8", "GBK", $value); |
其它方法
最后我采用phpMyAdmin的做法.用HTMLExcel, HTML我们比较熟悉,格式如下.
代码如下 | 复制代码 | ||||
xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns="http://www.w3.org/TR/REC-html40">
|
这下可以直接echo了,又不需要iconv转码,只要设置好HTML里的Content-type(这里用的是UTF-8),是不是有舒服的感觉呢? 当然header还是要加上
Php代码
代码如下 | 复制代码 |
header("Content-type:application/vnd.ms-excel"); header("Content-Disposition:attachment;filename=export_data.xls"); |
如果是导出中文名字也有可能出现乱码
解决文件名的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编码。
敢达决战官方正版 安卓版v6.7.9
下载敢达决战 安卓版v6.7.9
下载像素火影骨架佐助 (Perseverance Fire Shadow)手机版v1.16
下载要塞英雄 安卓版v33.20.0-39082670-Android
下载梦想城镇vivo最新版本 安卓版v12.0.1
梦想城镇vivo版是这款卡通风模拟经营类手游的渠道服版本,玩
怦然心动的瞬间 安卓版v1.0
怦然心动的瞬间是一款真人向的恋爱互动游戏,在游戏中玩家将扮演
曼尼汉堡店游戏 安卓版v1.0.3
曼尼汉堡店是一款非常好玩的精品恐怖类型冒险游戏,在这款游戏中
现代总统模拟器去广告版 安卓版v1.0.46
现代总统模拟器是一款休闲养成类游戏,可能对于不少的玩家来说都
现代总统模拟器付费完整版 安卓版v1.0.46
现代总统模拟器高级版在商店是需要付费的,相对于普通版本,高级