程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> java導出生成csv文件的辦法

java導出生成csv文件的辦法

編輯:關於JAVA

java導出生成csv文件的辦法。本站提示廣大學習愛好者:(java導出生成csv文件的辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是java導出生成csv文件的辦法正文


首先我們需求對csv文件有根底的看法,csv文件相似excel,可以運用excel翻開,但是csv文件的實質是逗號分隔的,比照如下圖:

txt中顯示:

修正文件後綴為csv後顯示如下:

在java中我們普通運用poi操作excel,導入,導出都可以,但是poi很耗費內存,尤其在導出時,這個時分我們其實可以選擇導出生成csv文件,由於其跟文本差不多,所以效率很高。

復雜寫了一個完成類,代碼如下:

/**
   *       
   *         導出生成csv格式的文件
   * @author     ccg
   * @param     titles csv格式頭文
   * @param     propertys 需求導出的數據實體的屬性,留意與title逐個對應
   * @param     list 需求導出的對象集合
   * @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");
    //構建輸入流,同時指定編碼
    OutputStreamWriter ow = new OutputStreamWriter(new FileOutputStream(file), "gbk");
    
    //csv文件是逗號分隔,除第一個外,每次寫入一個單元格數據後需求輸出逗號
    for(String title : titles){
      ow.write(title);
      ow.write(",");
    }
    //寫完文件頭後換行
    ow.write("\r\n");
    //寫內容
    for(Object obj : list){
      //應用反射獲取一切字段
      Field[] fields = obj.getClass().getDeclaredFields();
      for(String property : propertys){
        for(Field field : fields){
          //設置字段可見性
          field.setAccessible(true); 
          if(property.equals(field.getName())){
            ow.write(field.get(obj).toString());
            ow.write(",");
            continue;
          }
        }
      }
      //寫完一行換行
      ow.write("\r\n");
    }
    ow.flush();
    ow.close();
    return "0";
  }

測試類如下:

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);
  }

導出後生成的文件跟上圖一樣,算是一個封裝吧,傳入表頭,以及表頭對應實體的屬性即可,留意要逐個對應。

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支持。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved