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

Bytes Encoding Form

00 00 FE FF UTF-32, big-endian

php导出csv乱码解决PHP导出CSV文件中文乱码问题 Bootstrap

FF FE 00 00 UTF-32, little-endian

FE FF UTF-16, big-endian

FF FE UTF-16, little-endian

EF BB BF UTF-8

类Unix系统中并没有利用 BOM,由于它会毁坏现有的 ASCII 文件的语法约定。

我们在利用PHP导出csv文件时, 如果只利用file_put_contents 或者 fwrite 写入了表格数据, 而我们天生csv的平台不一定遵照微软的bom协议,导致如果输出非unicode编码的csv文件(例如utf-8),并且没有天生bom信息的话,Excel自动按照unicode编码读取,就会涌现乱码问题了。
而没有写入BOM头信息,就会涌现打开中文乱码的情形。

PHP中文乱码办理

Excel在读取csv的时候是通过读取文件头上的bom来识别编码的,如果文件头无bom信息,则默认按照unicode编码读取。

如果想利用utf-8格式,确保php源码是utf-8,我们可以在第一行写入utf-8对应的BOM信息

代码如下:

$bom = pack('CCC', 0xef, 0xbb, 0xbf); // 和上面的对应

file_put_contents('pythontab.csv',$bom, FILE_APPEND);

file_put_contents('pythontab.csv',$someData, FILE_APPEND); //写入你想要写入表格的数据

前后都省略了部分代码, 只写了最关键的部分, 其它部分大家自行补充即可。

这样天生的csv就不会涌现中文乱码问题啦。

把稳:写入的BOM头信息要和文件的编码对应。