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); }
導出後生成的文件跟上圖一樣,算是一個封裝吧,傳入表頭,以及表頭對應實體的屬性即可,留意要逐個對應。
以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支持。