您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

php导出excel中文乱码解决办法总结_PHP教程

2025/4/8 17:31:12发布43次查看
我的页面是用utf-8编码的,要怎么做才能保证导出的excel不会发生乱码?而且不同操作系统上面难道由于系统编码不同,所以一定要提供不同编码格式的文件进行下载吗?
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类
 代码如下 复制代码
class infomation
总结
导出之前需要转换为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>
1234 robbin会吐口水
5678 javaeye网站
这下可以直接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编码。
http://www.bkjia.com/phpjc/632176.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/632176.htmltecharticle我的页面是用utf-8编码的,要怎么做才能保证导出的excel不会发生乱码?而且不同操作系统上面难道由于系统编码不同,所以一定要提供不同...
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product