为了识别 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
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头信息要和文件的编码对应。