java導(dǎo)出生成csv文件的方法
本文實(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)題,需要的朋友可以參考下2014-04-04java編程中拷貝數(shù)組的方式及相關(guān)問(wèn)題分析
這篇文章主要介紹了java編程中拷貝數(shù)組的方式及相關(guān)問(wèn)題分析,分享了Java中數(shù)組復(fù)制的四種方式,其次對(duì)二維數(shù)組的簡(jiǎn)單使用有一段代碼示例,具有一定參考價(jià)值,需要的朋友可以了解下。2017-11-11java方法重載和參數(shù)類(lèi)型自動(dòng)提升方式
這篇文章主要介紹了java方法重載和參數(shù)類(lèi)型自動(dòng)提升方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02SpringMVC中Model與Session的區(qū)別說(shuō)明
這篇文章主要介紹了SpringMVC中Model與Session的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12SpringBoot中Elasticsearch的連接配置原理與使用詳解
Elasticsearch是一種開(kāi)源的分布式搜索和數(shù)據(jù)分析引擎,它可用于全文搜索、結(jié)構(gòu)化搜索、分析等應(yīng)用場(chǎng)景,本文主要介紹了SpringBoot中Elasticsearch的連接配置原理與使用詳解,感興趣的可以了解一下2023-09-09