避免UTF-8的csv文件打开中文出现乱码
来源:互联网 发布:nginx代理静态页面 编辑:程序博客网 时间:2024/05/21 09:38
最近又遇到了需要提供csv下载功能的需求,不同的时需要用java来实现,心想简单,就把以前php的版本重写了一遍,然后生成一份csv,用excel2007打开一看,里面的中文都是乱码,一下就懵了,以前好好的功能怎么突然不行了??以前也一直用2007的啊!于是开始了漫长的google之旅。
看来看去,说的都是输出utf-8格式的csv需要在文件头先输出BOM(BOM不懂的可以google了),即0xEF 0xBB 0xBF三个字节,这样更摸不着头脑了,明明是对的,偏偏不成功,直到发现一个帖子:http://stackoverflow.com/a/9337150/1794493 ,里面提到2007需要装sp3才能识别BOM,shit!原来是这回事!里面同时又提到,用utf-16le编码输出貌似更通用,经测试确实如此,但是utf-16le的BOM是0xFF 0xFE,帖子里面说错了!下面是一个简单的测试结果:
2007无utf-16leyes
2011无utf-8no2011无utf-16leyes
因为条件有限,只测试了这几个版本,可见utf-16le是更通用的编码格式。下面附上java代码,main方法中采用utf-16le编码,最后调用了utf8编码的方法,最后会输出两种编码格式的csv文件:
import java.io.*;/** * Created by zhaozhi on 15-5-29. */public class TestCSV { public static String join(String[] strArr, String delim) { StringBuilder sb = new StringBuilder(); for(String s : strArr) { sb.append(s); sb.append(delim); } String ret; if (strArr.length > 1) { ret = sb.substring(0, sb.length()-1); } else { ret = sb.toString(); } return ret; } public static void main (String[] args) throws Exception { String[] heads = {"日期", "产品", "订单数"}; String[][] rows = { {"20150228", "安卓", "23"}, {"20150301", "web", "34"} }; byte[] bom = {(byte)0xFF, (byte)0xFE}; String fname = "d:\\utf-16le.csv"; BufferedOutputStream bo = new BufferedOutputStream(new FileOutputStream(fname)); bo.write(bom); bo.write(join(heads, "\t").getBytes("utf-16le")); bo.write("\n".getBytes("utf-16le")); for (String[] row : rows) { bo.write(join(row, "\t").getBytes("utf-16le")); bo.write("\n".getBytes("utf-16le")); } bo.close(); UTF8(); } public static void UTF8() throws IOException { String line = "中文,标题,23"; OutputStream os = new FileOutputStream("d:/utf-8.csv"); os.write(239); // 0xEF os.write(187); // 0xBB os.write(191); // 0xBF PrintWriter w = new PrintWriter(new OutputStreamWriter(os, "UTF-8")); w.print(line); w.flush(); w.close(); }}
0 0
- 避免UTF-8的csv文件打开中文出现乱码
- 解决UTF-8编码的CSV文件在MICROSOFT EXCEL打开是中文乱码的方法
- java输出utf-8的csv文件时,文件中有中文,excel打开文件乱码问题解决
- 使用pycharm打开csv文件,csv文件中的中文出现乱码的解决方案
- 在mac下,用excel打开csv文件出现中文乱码的情况
- 解决PHP生成UTF-8编码的CSV文件用Excel打开乱码的问题
- 解决PHP生成UTF-8编码的CSV文件用Excel打开乱码的问题
- [置顶] 解决PHP生成UTF-8编码的CSV文件用Excel打开乱码的问题
- 如何解决PHP生成UTF-8编码的CSV文件用Excel打开乱码的问题
- 解决 Excel 打开 UTF-8 编码 CSV 文件乱码的 BUG
- java写utf-8编码的csv文件,用excel2007打开乱码
- excel打开UTF-8编码的CSV文件,添加BOM头后不再乱码
- 解决 Excel 打开 UTF-8 编码 CSV 文件乱码的 BUG
- JAVA以UTF-8导出CSV文件,用excel打开产生乱码的解决方法
- scala导出UTF-8的CSV文件用Excel打开乱码
- [转]解决 Excel 打开 UTF-8 编码 CSV 文件乱码的 BUG
- 简单有效:解决 Excel 打开 UTF-8 编码 CSV 文件乱码的 BUG
- Excel打开CSV文件中文乱码
- http://www.zhihuishi.com/class/1
- 归并排序
- MYSQL 日期函数大全
- windows配置redmine
- (5) 如何用Apache POI操作Excel文件-----发现Apache的POI的Bug后,如何给Apache的POI报Bug?
- 避免UTF-8的csv文件打开中文出现乱码
- MySQL 数据库性能优化之缓存参数优化
- 利用51单片机制作的电子时钟
- leetcode Binary Tree Level Order Traversal
- 揭开J2EE的面纱
- 第13周-多态性--项目0-课后实践·阅读程序2.
- MySQL 数据库性能优化之表结构
- 分享一个网站
- 菜鸟java记录四