UTF-8的CSV文件中文乱码问题解决办法

  最近工做中须要将一些数据写入CSV文件中,并要使用Excel打开进行查看。测试时发现,导出的CSV文件用Excel打开后,中文字符所有是乱码。写入CSV文件的是UTF-8编码的数据,文件在Linux中查看是没有问题的,在Windows上用Excel打开却有乱码。在查阅资料后发现,windows系统中文本文档的编码格式用BOM来指定,在文件的开头要写入字符:EF BB BF(UTF-8的BOM编码),这样UTF-8编码的文件才能被正确识别。因而修改代码,相似下边这样:html

FileOutputStream fos = new FileOutputStream(new File(this.csvFileAbsolutePath)); byte [] bs = { (byte)0xEF, (byte)0xBB, (byte)0xBF}; fos.write(bs);
//写入数据 fos.close()

  在CSV文件最前端写入BOM后,用Excel打开时就不会再有乱码了。前端

 

关于BOMwindows

  BOM(byte-order mark),即字节顺序标记,用于标记字节序的,也就是大小端。UTF- 8以字节为编码单元,没有字节序的问题,所以UTF-8不须要BOM来代表字节顺序,但能够用BOM来代表编码方式,在Windows系统中就是使用BOM来标记文本文件的编码方式的。UTF- 8的BOM编码是EF BB BF,Excel发现文件开头的EF BB BF就知道文件编码方式是UTF- 8,所以就能正常显示中文。测试

 

参考连接:this

  https://blog.csdn.net/zhaozhi406/article/details/46241415编码

  https://blog.csdn.net/u014563989/article/details/53087470spa

  http://www.fmddlmyy.cn/text6.html.net

  https://blog.csdn.net/yutianxu1986/article/details/82595290code

  https://blog.csdn.net/qq_35623773/article/details/87868608htm

相关文章
相关标签/搜索