Java写CSV文件,用Excel打开中文乱码

6 篇文章 0 订阅

原因是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();
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值