Java寫CSV文件,用Excel打開中文亂碼

原因是Excel通過文件的BOM頭來判斷文件編碼 https://blog.csdn.net/chichanma2003/article/details/100851467

但是我的和他的不一樣。

最後參考了 https://stackoverflow.com/questions/4389005/how-to-add-a-utf-8-bom-in-java 成功了!

但是,爲什麼 \ufeff = 0xEF 0xBB 0xBF 呢?長得不像啊!

void writeFile(String filename, String s) {
    File file = new File(MainActivity.dir, filename);
    try {
        BufferedWriter BW = new BufferedWriter(new FileWriter(file, false)); //false覆蓋
        if(filename.endsWith(".csv")){
            BW.write('\ufeff'); // Excel通過文件的BOM頭來判斷文件編碼
            BW.flush();
        }
        BW.write(s);
        BW.flush();
        Toast.makeText(getApplicationContext(), "寫文件 " + MainActivity.dir + File.separator + filename + " 成功", Toast.LENGTH_SHORT).show();
    } catch (Exception e) {
        Log.e(Thread.currentThread().getStackTrace()[2] + "", e.toString());
        Toast.makeText(getApplicationContext(), e.toString(), Toast.LENGTH_SHORT).show();
    }
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章