国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > Java > 正文

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

2019-11-26 13:17:07
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

首先我們需要對(duì)csv文件有基礎(chǔ)的認(rèn)識(shí),csv文件類似excel,可以使用excel打開,但是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)單寫了一個(gè)實(shí)現(xiàn)類,代碼如下:

/**   *          *         導(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è)外,每次寫入一個(gè)單元格數(shù)據(jù)后需要輸入逗號(hào)    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";  }

測(cè)試類如下:

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í)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 始兴县| 永修县| 宝兴县| 汾西县| 桓台县| 茂名市| 高淳县| 永平县| 亚东县| 德化县| 马龙县| 白沙| 邯郸县| 翁牛特旗| 平南县| 清水河县| 固原市| 观塘区| 鄂托克旗| 石嘴山市| 阳信县| 饶阳县| 德阳市| 康平县| 英吉沙县| 灵宝市| 鄂尔多斯市| 安达市| 横山县| 葫芦岛市| 西平县| 贵溪市| 苍山县| 红河县| 大化| 高淳县| 延津县| 房山区| 合肥市| 兰州市| 黄龙县|