温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java避免UTF-8的csv文件打开中文出现乱码怎么办

发布时间:2021-07-13 15:40:18 来源:亿速云 阅读:148 作者:小新 栏目:编程语言

这篇文章主要为大家展示了“Java避免UTF-8的csv文件打开中文出现乱码怎么办”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Java避免UTF-8的csv文件打开中文出现乱码怎么办”这篇文章吧。

具体如下:

最近又遇到了需要提供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,帖子里面说错了!下面是一个简单的测试结果:

excel版本附加包编码 测试结果
2007sp3utf-8yes
2007utf-8no
2007sp3utf-16leyes
2007utf-16leyes
2011utf-8no
2011utf-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();
  }
}

以上是“Java避免UTF-8的csv文件打开中文出现乱码怎么办”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI