原因:是由於輸出的CSV檔案中沒有BOM。
什麼是BOM?
在UCS 編碼中有一個叫做」ZERO WIDTH NO-BREAK SPACE」的字符,它的編碼是FEFF。而FFFE在UCS中是不存在的字符,所以就不應該出現在實際傳輸中。 UCS規範建議我們在傳輸位元組流前,先傳輸字元」ZERO WIDTH NO-BREAK SPACE」。這樣如果接收者收到FEFF,就表示這個位元組流是Big-Endian的;如果收到FFFE,就表示這個位元組流是Little- Endian的。因此字符”ZERO WIDTH NO-BREAK SPACE”又被稱為BOM。
UTF-8不需要BOM來表示位元組順序,但可以用BOM來表示編碼方式。字符”ZERO WIDTH NO-BREAK SPACE”的UTF-8編碼是EF BB BF。所以如果接收者收到以EF BB BF開頭的位元組流,就知道這是UTF-8編碼了。
Windows就是使用BOM來標記文字檔案的編碼方式的。
如何在PHP中輸出BOM?
在所有內容輸出之前
print(chr(0xEF).chr(0xBB).chr(0xBF));
範例程式碼:
<?php function writeCsvToFile($file,array $data){ $fp = fopen($file, 'w'); //Windows下使用BOM来标记文本文件的编码方式 fwrite($fp,chr(0xEF).chr(0xBB).chr(0xBF)); foreach ($data as $line) { fputcsv($fp, $line); } fclose($fp); }