php导出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类

 代码如下 复制代码

<?php
/*
 * Created on 2012-2-26
 *
 * To change the template for this generated file go to
 * Window - Preferences - PHPeclipse - PHP - Code Templates
 */
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:filename=php100.xls");
?>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<table>
 <tr>
  <td colspan="4"><font color="red" align="center">class infomation</font></td>
 </tr>
 <tr>
  <td><?php echo iconv("UTF-8", "GBK", "编号"); ?></td>
  <td><?php echo iconv("UTF-8", "GBK", "姓名"); ?></td>
  <td><?php echo iconv("UTF-8", "GBK", "学号"); ?></td>
  <td><?php echo iconv("UTF-8", "GBK", "性别"); ?></td>
 </tr>
</table>

总结

导出之前需要转换为GBK

 代码如下 复制代码

iconv("UTF-8", "GBK", $value);

其它方法

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

 代码如下 复制代码

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

这下可以直接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编码。

时间: 2024-08-07 13:03:31

php导出excel中文乱码解决办法总结的相关文章

php excel reader2.21导出excel中文乱码解决方法说明

之前我的PHP教程博客访友询问使用php excel reader2.21导出excel时中文出现乱码如何解决,现我说明下php excel reader导出excel中文乱码的解决方法,希望对使用php excel reader导出excel的朋友有所帮助. php excel reader介绍 php excel reader是一个读取Excel xsl文件内容的一个php excel类,目前最新版本是php excel reader2.21,网上可自行搜索,sourceforge上的php

windows server 2008 导出excel中文乱码

问题描述 windows server 2008 导出excel中文乱码 代码在本地运行没有问题,本地是win7 32位系统.发布到服务器上时会出现中文乱码.原因是编码格式不正确 解决方案http://support.microsoft.com/kb/954406#appliesto这里有一个微软提供的.但是治标不治本.在后台代码上设定编码没用,windows server 2008导出excel默认编码格式为:西欧(windows) 而windows server 2008要用Unicode.

关于cookie中文乱码解决办法

关于cookie中文乱码解决办法 后台: 存值 (使用 HttpUtility.UrlEncode 进行编码) Response.Cookies("ABC").Value = HttpUtility.UrlEncode("ABC") 取值 (使用 HttpUtility.UrlDecode 进行解码) Str = HttpUtility.UrlDecode(Request.Cookies("ABC").Value) 和JS进行交互: 在用js生成

数据库 MySQL中文乱码解决办法总结

MySQL中文乱码解决办法 前言: MySQL是我们项目中非常常用的数据型数据库.但是因为我们需要在数据库保存中文字符,所以经常遇到数据库乱码情况.下面就来介绍一下如何彻底解决数据库中文乱码情况. 1.中文乱码 1.1.中文乱码 create table user(name varchar(11)); # 创建user表 insert into table user("carl"); # 添加数据 select * from user; insert into user value(&

远程linux中文乱码解决办法

使用xshell登录中文版CentOS或者redhat时,在xshell下如果输出的是中文的话可能会显示乱码,通过如下办法可以有效的解决乱码问题 linux中文乱码解决方法如下: [root@localhost ~]# cd /etc/sysconfig/ [root@localhost sysconfig]# cp i18n i18n.bak #备份i18n文件 [root@localhost sysconfig]# echo "" >i18n [root@localhost

如何解决poi3.6版本导出excel中文乱码问题

问题描述 poi使用版本3.6,在进行导出中文后会出现乱码问题.查阅了一些资料,发现在3.0后似乎去掉了setEncoding方法,请问如果坚持使用3.6版本如何解决中文乱码问题.坚持使用原因的是项目中有很多地方使用了3.6的个别方法.谢谢 问题补充:梦中有你 写道 解决方案 恩 那就可以肯定不是写入之前的乱码,是Excel那边的问题了对了,那个Excel可以设置单元格值类型的 ,数字.日期.文本等待,看看是不是这个的事我写了一个JXL操作EXCEL的 我博客里有 那个我用 的时候就没乱码解决方

PHP中文乱码解决办法[转]

一.首先是PHP网页的编码 1.     php文件本身的编码与网页的编码应匹配 a.     如果欲使用gb2312编码,那么php要输出头:header("Content-Type: text/html; charset=gb2312"),静态页面添加<meta http-equiv="Content-Type" content="text/html; charset=gb2312">,所有文件的编码格式为ANSI,可用记事本打开

IntelliJ IDEA中文乱码解决办法

1. 预热 刚刚接触IntelliJ IDEA几天,在易用性方面的确比Eclipse好很多,比较智能,各种插件.工具都已经集成,和Mac OS X类似--开箱即用,并且在试用了之后在开源中国三折(后悔2折的时候没有下手)购买了授权. 但是还是老大难问题--中文乱码,让我不得不花费了一些时间去折腾它,这一点就不如Eclipse了,没有遇到过乱码问题. 乱码问题表现在使用Web Server(Tomcat.Jetty)时输出日志或者直接System.out.println("中文字符")时

Ajax在IE浏览器会出现中文乱码解决办法

在AJAX浏览器来进行发送数据时,一般它所默认的都是UTF-8的编码. Ajax在IE浏览器会出现中文乱码的情况!解决办法如下 <script type="text/javascript"> function showDiv(str){ document.getElementById("picDiv").style.display=""; var xmlhttp; if (str==""){ document.ge