请教一个问题
如下代码excel.php,运行后显示导出excel。  现在我把该文件另存为保存为utf-8格式后,则再次运行后则无法正常显示。
我现在想在 另外一个程序中比如 test.php 引入该excel.php文件,因为 test.php 编码格式是utf-8的,另存为也是utf-8的,引入后就会显示不正确,提示Warning: Cannot modify header information - headers already sent by (output started at C:\AppServ\www\appserv\excel.php:1) in C:\AppServ\www\appserv\test.php on line 3
e请问如何解决,谢谢!<?php 
header("Content-type:application/vnd.ms-excel"); 
header("Content-Disposition:filename=test.xls"); 
           echo "test11\t"; 
           echo "test12\t\n"; 
           echo "test21\t"; 
           echo "test22\t\n"; 
           echo "test31\t"; 
           echo "test32\t\n"; 
           echo "test41\t"; 
           echo "test42\t\n"; 
           echo "test51\t"; 
           echo "test52\t\n"; 
           echo "test61\t"; 
           echo "test62\t\n"; 
?>

解决方案 »

  1.   

    utf-8文件头 保存为无头utf-8 应该就可以了. Remove BOM.
      

  2.   

    本帖最后由 xuzuning 于 2012-06-08 18:38:32 编辑
      

  3.   

    WINDOWS平台的BOM真是一个恶心的东西啊。
      

  4.   

    excel 是微软的东西,utf-8 不是微软的东西
    弄在一起总是要打架的
      

  5.   

    这只是生成了一种能用excel打开的文件,并不是真正的excel建议使用phpexcel来生成。
    上次问题远不止此。
      

  6.   

    我们在运用PHP语言进行Excel文件导出时可能会遇到乱码的问题,PHP导出Excel乱码具体的解决方法在本文中将会做详细的介绍。PHP导出Excel文件时有两个主要的过程:定义文件名和填充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编码)。http://www.phpnewer.com/index.php/Cjwt/detail/id/239