欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java避免UTF-8的csv文件打開中文出現(xiàn)亂碼的方法

 更新時間:2019年07月19日 11:23:58   作者:zhaozhi406  
這篇文章主要介紹了Java避免UTF-8的csv文件打開中文出現(xiàn)亂碼的方法,結(jié)合實例形式分析了java操作csv文件時使用utf-16le編碼與utf8編碼相關操作技巧,需要的朋友可以參考下

本文實例講述了Java避免UTF-8的csv文件打開中文出現(xiàn)亂碼的方法。分享給大家供大家參考,具體如下:

最近又遇到了需要提供csv下載功能的需求,不同的時需要用java來實現(xiàn),心想簡單,就把以前php的版本重寫了一遍,然后生成一份csv,用excel2007打開一看,里面的中文都是亂碼,一下就懵了,以前好好的功能怎么突然不行了??以前也一直用2007的??!于是開始了漫長的google之旅。

看來看去,說的都是輸出utf-8格式的csv需要在文件頭先輸出BOM(BOM不懂的可以google了),即0xEF 0xBB 0xBF三個字節(jié),這樣更摸不著頭腦了,明明是對的,偏偏不成功,直到發(fā)現(xiàn)一個帖子:http://stackoverflow.com/a/9337150/1794493 ,里面提到2007需要裝sp3才能識別BOM,shit!原來是這回事!里面同時又提到,用utf-16le編碼輸出貌似更通用,經(jīng)測試確實如此,但是utf-16le的BOM是0xFF 0xFE,帖子里面說錯了!下面是一個簡單的測試結(jié)果:

excel版本 附加包 編碼  測試結(jié)果
2007 sp3 utf-8 yes
2007 utf-8 no
2007 sp3 utf-16le yes
2007 utf-16le yes
2011 utf-8 no
2011 utf-16le yes

因為條件有限,只測試了這幾個版本,可見utf-16le是更通用的編碼格式。下面附上java代碼,main方法中采用utf-16le編碼,最后調(diào)用了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 = {"日期", "產(chǎn)品", "訂單數(shù)"};
    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相關內(nèi)容感興趣的讀者可查看本站專題:《Java編碼操作技巧總結(jié)》、《Java數(shù)學運算技巧總結(jié)》、《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java字符與字符串操作技巧總結(jié)》、《Java操作DOM節(jié)點技巧總結(jié)》和《Java緩存操作技巧匯總

希望本文所述對大家java程序設計有所幫助。

相關文章

  • 一文帶你探究Spring中Bean的線程安全性問題

    一文帶你探究Spring中Bean的線程安全性問題

    很多人都想spring中的bean是線程安全的嗎?本文將帶你探究Spring中Bean的線程安全性問題,感興趣的同學可以參考閱讀下
    2023-05-05
  • 基于Java HashMap的死循環(huán)的啟示詳解

    基于Java HashMap的死循環(huán)的啟示詳解

    本篇文章是對Java HashMap的死循環(huán)進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • mybatis Example Criteria like 模糊查詢問題

    mybatis Example Criteria like 模糊查詢問題

    這篇文章主要介紹了mybatis Example Criteria like 模糊查詢問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • java多線程學習筆記之自定義線程池

    java多線程學習筆記之自定義線程池

    本篇文章主要介紹了java多線程學習筆記之自定義線程池 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • java基礎之字符串編碼知識點總結(jié)

    java基礎之字符串編碼知識點總結(jié)

    這篇文章主要介紹了java基礎之字符串編碼總結(jié),文中有非常詳細的代碼示例,對正在學習java基礎的小伙伴們有很好的幫助,要的朋友可以參考下
    2021-04-04
  • Spring Boot自動注入的原理分析

    Spring Boot自動注入的原理分析

    這篇文章主要給大家分析介紹了關于Spring Boot自動注入的原理,文中通過示例代碼介紹的非常詳細,對大家的學習或者使用Spring Boot自具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-10-10
  • 用Java實現(xiàn)簡單畫板功能

    用Java實現(xiàn)簡單畫板功能

    這篇文章主要為大家詳細介紹了用Java實現(xiàn)簡單畫板功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • Java泛型的用法及T.class的獲取過程解析

    Java泛型的用法及T.class的獲取過程解析

    這篇文章主要介紹了Java泛型的用法及T.class的獲取過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-11-11
  • springboot+websocket+redis搭建的實現(xiàn)

    springboot+websocket+redis搭建的實現(xiàn)

    這篇文章主要介紹了springboot+websocket+redis搭建的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • IDEA中設置Tab健為4個空格的方法

    IDEA中設置Tab健為4個空格的方法

    這篇文章給大家介紹了代碼縮進用空格還是Tab?(IDEA中設置Tab健為4個空格)的相關知識,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2021-03-03

最新評論