php 生成csv utf8 bom,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函数:

代码示例:

总结:

1,output_csv函数使用前,确保php源码是utf-8,并且无BOM,并且没有输出任何内容。

2,BOM实际上挺烦人,如果网页(*.html)有BOM,在IE6.x下打开会发现空行,Firefox下没有。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值