日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

六.实战——Excel表格的导入和导出

發(fā)布時間:2023/12/14 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 六.实战——Excel表格的导入和导出 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

總結:

  • 導出:寫操作,將數(shù)據(jù)庫中的內容寫入到excel表格中。
  • 導入:讀操作,將excel表格中的內容出來,插入到數(shù)據(jù)庫中,一般都是先將excel表格中的內容使用流,讀到集合(list)中,然后再對集合進行遍歷插入。
  • 一. easyExcel

    1. 寫(導出)

    (1)pom依賴

    <!--導入依賴--> <dependencies><!--fastjson--><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version >1.2.62</version></dependency><!--easyexcel--><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version >2.2.0-beta2</version></dependency><!--日期格式化工具--><dependency><groupId>joda-time</groupId><artifactId>joda-time</artifactId><version>2.10.1</version></dependency><!--test--><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>RELEASE</version><scope>compile</scope></dependency> </dependencies>

    (2)實體類(模板類)

    字段上加注解就行:
    @ExcelProperty("表中字段名")
    @ExcelIgnore:要忽略的字段。

    (3)業(yè)務層進行寫操作

    EasyExcel.write(文件名, 模板類.class).sheet("表名").doWrite(list集合);

    2. 讀(導入)

    (1)監(jiān)聽器

    // 1.繼承AnalysisEventListener public class DemoDataListener extends AnalysisEventListener<DemoData> {// 2.一行一行的讀取內容(list集合),但是不讀表頭。@Overridepublic void invoke(DemoData data, AnalysisContext context) {//一般在這里進行導入集合操作(在項目中,一般所有業(yè)務操作,都在這個方法中進行)}// 3.讀表頭內容@Overridepublic void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {//將表頭信息導入集合(實際中不需要)}// 4.所有都讀取完了,執(zhí)行這個方法@Overridepublic void doAfterAllAnalysed(AnalysisContext context) {//一般在這里進行插入數(shù)據(jù)庫操作(當然這只是我個人認為的,在尚醫(yī)通項目和在線教育項目中,這個項目都是空的,插入數(shù)據(jù)庫的操作在invoke()方法中進行。而且invokeHeadMap方法也用不到,因為不需要讀取表頭信息,讀取時導入,數(shù)據(jù)庫中有字段(表頭),不需要再導)//狂神講的課中用到了這個方法,可以具體去看一下他的筆記} }

    (2)讀

    //EasyExcel.read(fileName, DemoData.class, new DemoDataListener()).sheet().doRead(); EasyExcel.read(文件名, 模板類.class, 監(jiān)聽器對象).sheet().doRead();

    更多詳細信息,可以看尚醫(yī)通的筆記(語雀)。
    https://www.yuque.com/docs/share/3df0e6c8-54d4-4b4c-9c2b-dc188e47345c?# 《EasyExcel》

    二. POI-Excel

    與EasyExcel相比,這個要難得多,比如:沒有注解的使用,要導入表頭部分需要手動導入。但是可以對POI-Excel進行封裝,例如若依項目,就是對POI-Excel做了封裝,讓POI-Excel也可以使用注解,用法難度也不高,很。。可惡,被他裝到了。但是我認為,還是使用EasyExcel簡單方便一些(畢竟是阿里的)。
    如果要問若依項目是如何對poi-excel進行封裝的,那就是反射機制。不得不說封裝的真大啊!
    下面是若依如何獲取表頭的代碼:

    /*** 獲取字段注解信息*/public List<Object[]> getFields(){List<Object[]> fields = new ArrayList<Object[]>();List<Field> tempFields = new ArrayList<>();tempFields.addAll(Arrays.asList(clazz.getSuperclass().getDeclaredFields()));tempFields.addAll(Arrays.asList(clazz.getDeclaredFields()));for (Field field : tempFields){// 單注解if (field.isAnnotationPresent(Excel.class)){Excel attr = field.getAnnotation(Excel.class);if (attr != null && (attr.type() == Type.ALL || attr.type() == type)){field.setAccessible(true);fields.add(new Object[] { field, attr });}}// 多注解if (field.isAnnotationPresent(Excels.class)){Excels attrs = field.getAnnotation(Excels.class);Excel[] excels = attrs.value();for (Excel attr : excels){if (attr != null && (attr.type() == Type.ALL || attr.type() == type)){field.setAccessible(true);fields.add(new Object[] { field, attr });}}}}return fields;}

    總結

    以上是生活随笔為你收集整理的六.实战——Excel表格的导入和导出的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內容還不錯,歡迎將生活随笔推薦給好友。