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

我的页面是用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类

  1. <?php 
  2. /* 
  3.  * Created on 2012-2-26 
  4.  * 
  5.  * To change the template for this generated file go to 
  6.  * Window – Preferences – PHPeclipse – PHP – Code Templates 
  7.  */ 
  8. header("Content-type:application/vnd.ms-excel"); 
  9. header("Content-Disposition:filename=php100.xls"); 
  10. ?> 
  11. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> 
  12. <table> 
  13.  <tr> 
  14.   <td colspan="4"><font color="red" align="center">class infomation</font></td> 
  15.  </tr> 
  16.  <tr> 
  17.   <td><?php echo iconv("UTF-8""GBK""编号"); ?></td> 
  18.   <td><?php echo iconv("UTF-8""GBK""姓名"); ?></td> 
  19.   <td><?php echo iconv("UTF-8""GBK""学号"); ?></td> 
  20.   <td><?php echo iconv("UTF-8""GBK""性别"); ?></td> 
  21.  </tr> 
  22. </table> 

总结:导出之前需要转换为GBK:iconv("UTF-8", "GBK", $value);

其它方法:最后我采用phpMyAdmin的做法.用HTMLExcel, HTML我们比较熟悉,格式如下.

  1. <html xmlns:o="urn:schemas-microsoft-com:office:office" 
  2. xmlns:x="urn:schemas-microsoft-com:office:excel" 
  3. xmlns="http://www.w3.org/TR/REC-html40"
  4. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
  5. <html> 
  6.  <head> 
  7.   <meta http-equiv="Content-type" content="text/html;charset=UTF-8" /> 
  8.   <style id="Classeur1_16681_Styles"></style> 
  9.  </head> 
  10.  <body> 
  11.   <div id="Classeur1_16681" align=center x:publishsource="Excel"
  12.    <table x:str border=0 cellpadding=0 cellspacing=0 width=100% style="border-collapse: collapse"
  13.     <tr><td class=xl2216681 nowrap>1234</td><td class=xl2216681 nowrap>Robbin会吐口水</td></tr> 
  14.     <tr><td class=xl2216681 nowrap>5678</td><td class=xl2216681 nowrap>javaeye网站</td></tr> 
  15.    </table> 
  16.   </div> 
  17.  </body> 
  18. </html> 

这下可以直接echo了,又不需要iconv转码,只要设置好HTML里的Content-type(这里用的是UTF-8),是不是有舒服的感觉呢? 当然header还是要加上

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编码。

波比源码 – 精品源码模版分享 | www.bobi11.com
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 本站源码并不保证全部能正常使用,仅供有技术基础的人学习研究,请谨慎下载
8. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!

波比源码 » php导出excel中文乱码解决办法总结

发表评论

Hi, 如果你对这款模板有疑问,可以跟我联系哦!

联系站长
赞助VIP 享更多特权,建议使用 QQ 登录
喜欢我嘛?喜欢就按“ctrl+D”收藏我吧!♡