首頁  >  文章  >  後端開發  >  php產生UTF-8編碼的CSV檔案用Excel開啟亂碼的解決辦法

php產生UTF-8編碼的CSV檔案用Excel開啟亂碼的解決辦法

伊谢尔伦
伊谢尔伦原創
2016-12-02 09:59:091299瀏覽

原因:是由於輸出的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, &#39;w&#39;);
        //Windows下使用BOM来标记文本文件的编码方式
        fwrite($fp,chr(0xEF).chr(0xBB).chr(0xBF));
        foreach ($data as $line) {
            fputcsv($fp, $line);
        }
        fclose($fp);
    }


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn