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

java導(dǎo)出生成csv文件的方法

 更新時(shí)間:2020年12月31日 11:19:54   作者:FlyHeLanMan  
這篇文章主要為大家詳細(xì)介紹了java導(dǎo)出生成csv文件的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了java導(dǎo)出生成csv文件的具體代碼,供大家參考,具體內(nèi)容如下

首先我們需要對(duì)csv文件有基礎(chǔ)的認(rèn)識(shí),csv文件類(lèi)似excel,可以使用excel打開(kāi),但是csv文件的本質(zhì)是逗號(hào)分隔的,對(duì)比如下圖:

txt中顯示:

修改文件后綴為csv后顯示如下:

在java中我們一般使用poi操作excel,導(dǎo)入,導(dǎo)出都可以,但是poi很消耗內(nèi)存,尤其在導(dǎo)出時(shí),這個(gè)時(shí)候我們其實(shí)可以選擇導(dǎo)出生成csv文件,因?yàn)槠涓谋静畈欢啵孕屎芨摺?/p>

簡(jiǎn)單寫(xiě)了一個(gè)實(shí)現(xiàn)類(lèi),代碼如下:

/**
  *    
  *     導(dǎo)出生成csv格式的文件
  * @author   ccg
  * @param   titles csv格式頭文
  * @param   propertys 需要導(dǎo)出的數(shù)據(jù)實(shí)體的屬性,注意與title一一對(duì)應(yīng)
  * @param   list 需要導(dǎo)出的對(duì)象集合
  * @return
  * @throws   IOException
  * Created   2017年1月5日 上午10:51:44
  * @throws   IllegalAccessException 
  * @throws   IllegalArgumentException 
  */
 public static <T> String exportCsv(String[] titles,String[] propertys,List<T> list) throws IOException, IllegalArgumentException, IllegalAccessException{
  File file = new File("d:\\test.csv");
  //構(gòu)建輸出流,同時(shí)指定編碼
  OutputStreamWriter ow = new OutputStreamWriter(new FileOutputStream(file), "gbk");
  
  //csv文件是逗號(hào)分隔,除第一個(gè)外,每次寫(xiě)入一個(gè)單元格數(shù)據(jù)后需要輸入逗號(hào)
  for(String title : titles){
   ow.write(title);
   ow.write(",");
  }
  //寫(xiě)完文件頭后換行
  ow.write("\r\n");
  //寫(xiě)內(nèi)容
  for(Object obj : list){
   //利用反射獲取所有字段
   Field[] fields = obj.getClass().getDeclaredFields();
   for(String property : propertys){
    for(Field field : fields){
     //設(shè)置字段可見(jiàn)性
     field.setAccessible(true); 
     if(property.equals(field.getName())){
      ow.write(field.get(obj).toString());
      ow.write(",");
      continue;
     }
    }
   }
   //寫(xiě)完一行換行
   ow.write("\r\n");
  }
  ow.flush();
  ow.close();
  return "0";
 }

測(cè)試類(lèi)如下:

public void test() throws IOException, IllegalArgumentException, IllegalAccessException{
  String[] titles = new String[]{"ID","姓名"};
  String[] propertys = new String[]{"id","name"};
  List<User> list = new ArrayList<User>();
  User user;
  user = new User();
  user.setId(1L);
  user.setName("張三");
  list.add(user);
  user = new User();
  user.setId(2L);
  user.setName("李四");
  list.add(user);
  CsvUtil.getInstance().exportCsv(titles,propertys, list);
 }

導(dǎo)出后生成的文件跟上圖一樣,算是一個(gè)封裝吧,傳入表頭,以及表頭對(duì)應(yīng)實(shí)體的屬性即可,注意要一一對(duì)應(yīng)。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java中String類(lèi)(字符串操作)的10個(gè)常見(jiàn)問(wèn)題和解決方法

    Java中String類(lèi)(字符串操作)的10個(gè)常見(jiàn)問(wèn)題和解決方法

    這篇文章主要介紹了Java中String類(lèi)(字符串)操作的10個(gè)常見(jiàn)問(wèn)題,需要的朋友可以參考下
    2014-04-04
  • 實(shí)例講解JAVA 適配器模式

    實(shí)例講解JAVA 適配器模式

    這篇文章主要介紹了JAVA 適配器模式的的相關(guān)資料,文中示例代碼非常詳細(xì),供大家參考和學(xué)習(xí),感興趣的朋友可以了解下
    2020-06-06
  • 深入理解窗口令牌WindowToken

    深入理解窗口令牌WindowToken

    這篇文章主要介紹了窗口令牌WindowToken的概念與作用,它是對(duì)應(yīng)用組件的行為進(jìn)行規(guī)范管理的一個(gè)手段。WindowToken由應(yīng)用組件或其管理者負(fù)責(zé)向WMS聲明并持有
    2021-08-08
  • IDEA+Maven打JAR包的兩種方法步驟詳解

    IDEA+Maven打JAR包的兩種方法步驟詳解

    Idea中為一般的非Web項(xiàng)目打Jar包是有自己的方法的,下面這篇文章主要給大家介紹了關(guān)于IDEA+Maven打JAR包的兩種方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • java編程中拷貝數(shù)組的方式及相關(guān)問(wèn)題分析

    java編程中拷貝數(shù)組的方式及相關(guān)問(wèn)題分析

    這篇文章主要介紹了java編程中拷貝數(shù)組的方式及相關(guān)問(wèn)題分析,分享了Java中數(shù)組復(fù)制的四種方式,其次對(duì)二維數(shù)組的簡(jiǎn)單使用有一段代碼示例,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11
  • 淺談Maven Wrapper

    淺談Maven Wrapper

    這篇文章主要介紹了淺談Maven Wrapper,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • java方法重載和參數(shù)類(lèi)型自動(dòng)提升方式

    java方法重載和參數(shù)類(lèi)型自動(dòng)提升方式

    這篇文章主要介紹了java方法重載和參數(shù)類(lèi)型自動(dòng)提升方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • Java編寫(xiě)實(shí)現(xiàn)登陸窗口

    Java編寫(xiě)實(shí)現(xiàn)登陸窗口

    這篇文章主要為大家詳細(xì)介紹了Java編寫(xiě)實(shí)現(xiàn)登陸窗口,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • SpringMVC中Model與Session的區(qū)別說(shuō)明

    SpringMVC中Model與Session的區(qū)別說(shuō)明

    這篇文章主要介紹了SpringMVC中Model與Session的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • SpringBoot中Elasticsearch的連接配置原理與使用詳解

    SpringBoot中Elasticsearch的連接配置原理與使用詳解

    Elasticsearch是一種開(kāi)源的分布式搜索和數(shù)據(jù)分析引擎,它可用于全文搜索、結(jié)構(gòu)化搜索、分析等應(yīng)用場(chǎng)景,本文主要介紹了SpringBoot中Elasticsearch的連接配置原理與使用詳解,感興趣的可以了解一下
    2023-09-09

最新評(píng)論