打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
UTF

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

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

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

关于BOM

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

参考链接:

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

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

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

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

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

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
避免使用For循环
卷积层输出大小计算
linux 内核中断相关阅读记录
TCPCopy 总结
io流 java 添加bom头 文件前面添加内容
No resource identifier found for attribute 'appComponentFactory' in package 'android&#39
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服