教程集 www.jiaochengji.com
教程集 >  脚本编程  >  php  >  正文 php导出csv文件打开乱码的解决方法

php导出csv文件打开乱码的解决方法

发布时间:2017-08-24   编辑:jiaochengji.com
本文分享下,php导出csv文件,打开查看时有乱码问题的解决方法,有需要的朋友参考下。

在php编程中,经常会导出数据为excel或csv文件,不过为了操作方便,大多时候我们会用php导出csv文件。

CSV,Comma Separator Value,常常用来数据转换的中间文件存在。
使用utf-8编码导出CSV文件,打开后中文成了乱码(Windows下CSV文件默认与Microsoft Excel关联),用Notepad++或者Word打开正常。

原因分析:
BOM惹的祸,微软惹的祸。

什么是BOM?Byte Order Mark。

为了识别 Unicode 文件,Microsoft 建议所有的 Unicode 文件应该以 ZERO WIDTH NOBREAK SPACE字符开头。这作为一个"特征符"或"字节顺序标记(byte-order mark,BOM)"来识别文件中使用的编码和字节顺序(big-endian或little-endian),具体的对应关系见下表。
 

BytesEncoding Form00 00 FE FFUTF-32
big-endianFF FE 00 00UTF-32
little-endianFE FFUTF-16
big-endianFF FEUTF-16
little-endianEF BB BFUTF-8

Unix系统中并没有使用 BOM,因为它会破坏现有的 ASCII 文件的语法约定。

php源码文件是用NotePad++生成的,在Centos下执行,格式为:以UTF-8无BOM格式编码,因此要想导出Microsoft Excel可以正常显示的UTF-8的CSV文件,需要显式的输出BOM(EF BB BF,上表的最后一种类型),然后再输出Mysql中的有效数据。

实现如下的php函数:
 

复制代码 代码示例:
<?php
/**
* @param $file_name string 要导出的文件名,比如:mail-list.csv
* @param $content string 要输出的csv格式的数据,用逗号分隔各字段
* @return null
*/
function output_csv($file_name,$content)
{
$content = "\xEF\xBB\xBF".$content; //添加BOM
if( empty( $file_name ) )
{
$file_name = date("Ymd")."csv";
}
header( "Cache-Control: public" );
header( "Pragma: public" );
header( "Content-type: text/csv" ) ;
header( "Content-Dis; filename={$file_name}" ) ;
header( "Content-Length: ". strlen( $content ) );
echo $content;
exit;
}
?>

总结:
1,output_csv函数使用前,确保php源码是utf-8,并且无BOM,并且没有输出任何内容。
2,BOM实际上挺烦人,如果网页(*.html)有BOM,在IE6.x下打开会发现空行,Firefox下没有。

您可能感兴趣的文章:
php导出csv时身份证号禁止科学计数
php导出csv文件乱码问题的解决实例
PHP生成UTF-8编码的CSV文件打开乱码的解决方法
php导入csv文件中文乱码的解决方法
解决php csv文件导入mysql中文乱码
解决PHP导出CSV文中文乱码问题
解决php导出csv文件乱码的问题(图文)
php导出csv文件打开乱码的解决方法
php网页标题中文乱码如何解决
使用PHP导入与导出CSV文件实例详解

关键词: php csv  php导出csv  乱码   
[关闭]
~ ~