java導(dǎo)出生成csv文件的方法
本文實例為大家分享了java導(dǎo)出生成csv文件的具體代碼,供大家參考,具體內(nèi)容如下
首先我們需要對csv文件有基礎(chǔ)的認識,csv文件類似excel,可以使用excel打開,但是csv文件的本質(zhì)是逗號分隔的,對比如下圖:
txt中顯示:

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

在java中我們一般使用poi操作excel,導(dǎo)入,導(dǎo)出都可以,但是poi很消耗內(nèi)存,尤其在導(dǎo)出時,這個時候我們其實可以選擇導(dǎo)出生成csv文件,因為其跟文本差不多,所以效率很高。
簡單寫了一個實現(xiàn)類,代碼如下:
/**
*
* 導(dǎo)出生成csv格式的文件
* @author ccg
* @param titles csv格式頭文
* @param propertys 需要導(dǎo)出的數(shù)據(jù)實體的屬性,注意與title一一對應(yīng)
* @param list 需要導(dǎo)出的對象集合
* @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)建輸出流,同時指定編碼
OutputStreamWriter ow = new OutputStreamWriter(new FileOutputStream(file), "gbk");
//csv文件是逗號分隔,除第一個外,每次寫入一個單元格數(shù)據(jù)后需要輸入逗號
for(String title : titles){
ow.write(title);
ow.write(",");
}
//寫完文件頭后換行
ow.write("\r\n");
//寫內(nèi)容
for(Object obj : list){
//利用反射獲取所有字段
Field[] fields = obj.getClass().getDeclaredFields();
for(String property : propertys){
for(Field field : fields){
//設(shè)置字段可見性
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);
}
導(dǎo)出后生成的文件跟上圖一樣,算是一個封裝吧,傳入表頭,以及表頭對應(yīng)實體的屬性即可,注意要一一對應(yīng)。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何使用Spring Security實現(xiàn)用戶-角色-資源的權(quán)限控制
文章介紹了如何通過SpringSecurity實現(xiàn)用戶-角色-資源的權(quán)限管理,包括基于角色的請求控制、加載用戶角色信息、角色與資源的關(guān)聯(lián)等步驟,同時,提供了一些測試場景,以驗證權(quán)限控制是否正確,感興趣的朋友跟隨小編一起看看吧2024-10-10
深入探究Java線程的創(chuàng)建與構(gòu)造方法
這篇文章主要給大家分享的是java線程的創(chuàng)建以及構(gòu)造方法,想了解具體方式的小伙伴可以參考下面文章內(nèi)容,希望對你有所幫助2022-04-04
Java實現(xiàn)后臺發(fā)送及接收json數(shù)據(jù)的方法示例
這篇文章主要介紹了Java實現(xiàn)后臺發(fā)送及接收json數(shù)據(jù)的方法,結(jié)合實例形式分析了java針對json格式數(shù)據(jù)的傳輸與操作相關(guān)技巧,需要的朋友可以參考下2018-12-12

