六.实战——Excel表格的导入和导出
生活随笔
收集整理的這篇文章主要介紹了
六.实战——Excel表格的导入和导出
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
總結(jié):
一. easyExcel
1. 寫(xiě)(導(dǎo)出)
(1)pom依賴
<!--導(dǎo)入依賴--> <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)實(shí)體類(模板類)
字段上加注解就行:
@ExcelProperty("表中字段名")
@ExcelIgnore:要忽略的字段。
(3)業(yè)務(wù)層進(jìn)行寫(xiě)操作
EasyExcel.write(文件名, 模板類.class).sheet("表名").doWrite(list集合);2. 讀(導(dǎo)入)
(1)監(jiān)聽(tīng)器
// 1.繼承AnalysisEventListener public class DemoDataListener extends AnalysisEventListener<DemoData> {// 2.一行一行的讀取內(nèi)容(list集合),但是不讀表頭。@Overridepublic void invoke(DemoData data, AnalysisContext context) {//一般在這里進(jìn)行導(dǎo)入集合操作(在項(xiàng)目中,一般所有業(yè)務(wù)操作,都在這個(gè)方法中進(jìn)行)}// 3.讀表頭內(nèi)容@Overridepublic void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {//將表頭信息導(dǎo)入集合(實(shí)際中不需要)}// 4.所有都讀取完了,執(zhí)行這個(gè)方法@Overridepublic void doAfterAllAnalysed(AnalysisContext context) {//一般在這里進(jìn)行插入數(shù)據(jù)庫(kù)操作(當(dāng)然這只是我個(gè)人認(rèn)為的,在尚醫(yī)通項(xiàng)目和在線教育項(xiàng)目中,這個(gè)項(xiàng)目都是空的,插入數(shù)據(jù)庫(kù)的操作在invoke()方法中進(jìn)行。而且invokeHeadMap方法也用不到,因?yàn)椴恍枰x取表頭信息,讀取時(shí)導(dǎo)入,數(shù)據(jù)庫(kù)中有字段(表頭),不需要再導(dǎo))//狂神講的課中用到了這個(gè)方法,可以具體去看一下他的筆記} }(2)讀
//EasyExcel.read(fileName, DemoData.class, new DemoDataListener()).sheet().doRead(); EasyExcel.read(文件名, 模板類.class, 監(jiān)聽(tīng)器對(duì)象).sheet().doRead();更多詳細(xì)信息,可以看尚醫(yī)通的筆記(語(yǔ)雀)。
https://www.yuque.com/docs/share/3df0e6c8-54d4-4b4c-9c2b-dc188e47345c?# 《EasyExcel》
二. POI-Excel
與EasyExcel相比,這個(gè)要難得多,比如:沒(méi)有注解的使用,要導(dǎo)入表頭部分需要手動(dòng)導(dǎo)入。但是可以對(duì)POI-Excel進(jìn)行封裝,例如若依項(xiàng)目,就是對(duì)POI-Excel做了封裝,讓POI-Excel也可以使用注解,用法難度也不高,很。。可惡,被他裝到了。但是我認(rèn)為,還是使用EasyExcel簡(jiǎn)單方便一些(畢竟是阿里的)。
如果要問(wèn)若依項(xiàng)目是如何對(duì)poi-excel進(jìn)行封裝的,那就是反射機(jī)制。不得不說(shuō)封裝的真大啊!
下面是若依如何獲取表頭的代碼:
總結(jié)
以上是生活随笔為你收集整理的六.实战——Excel表格的导入和导出的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 你用什么软件做笔记?
- 下一篇: 【Labview】G语言