Java中easypoi導(dǎo)入excel文件列名相同的處理方案
Easypoi是什么
Easypoi 功能如同名字easy,主打的功能就是容易,讓一個(gè)沒(méi)接觸過(guò)poi的人員,就可以方便的寫(xiě)出Excel導(dǎo)出、Excel模板導(dǎo)出、Excel導(dǎo)入、Word模板導(dǎo)出,通過(guò)簡(jiǎn)單的注解和模板語(yǔ)言(熟悉的表達(dá)式fe語(yǔ)法),完成以前復(fù)雜的寫(xiě)法
開(kāi)源地址:https://gitee.com/lemur/easypoi
獨(dú)特的功能
- 基于注解的導(dǎo)入導(dǎo)出,修改注解就可以修改Excel
- 支持常用的樣式自定義
- 基于map可以靈活定義的表頭字段
- 支持一堆多的導(dǎo)出,導(dǎo)入
- 支持模板的導(dǎo)出,一些常見(jiàn)的標(biāo)簽,自定義標(biāo)簽
- 支持HTML/Excel轉(zhuǎn)換,如果模板還不能滿(mǎn)足用戶(hù)的變態(tài)需求,請(qǐng)用這個(gè)功能
- 支持word的導(dǎo)出,支持圖片,Excel
更多特性與功能詳解:easypoi官網(wǎng)說(shuō)明
官方demo
官網(wǎng)實(shí)例工程:easypoi-test
導(dǎo)入
1. 指定模板導(dǎo)入
在導(dǎo)入指定Excel模板的過(guò)程中,可能會(huì)碰到列名重復(fù)的問(wèn)題,當(dāng)我們使用Easypoi的注解方式進(jìn)行導(dǎo)入時(shí),會(huì)發(fā)現(xiàn)出現(xiàn)丟失數(shù)據(jù)的情況,原因是源碼在解析注解映射關(guān)系的時(shí)候,使用的map進(jìn)行存儲(chǔ),當(dāng)實(shí)體的注解存在相同名稱(chēng)時(shí),key會(huì)被重新覆蓋,導(dǎo)致數(shù)據(jù)列丟失,如圖通過(guò)添加fixedIndex屬性得以解決:

需要注意的是:fixedIndex是從0開(kāi)始
Excel文件如圖:

2. Map自由導(dǎo)入
ImportParams importParams = new ImportParams();
importParams.setTitleRows(3);//標(biāo)題行
importParams.setHeadRows(1);//表頭行
importParams.setStartSheetIndex(0);//開(kāi)始的sheet下標(biāo)
importParams.setKeyIndex(null);//設(shè)置讀取空值
File file = new File("/file/file.xlsx");//文件路徑
try {
List<Map> list = ExcelImportUtil.importExcel(file, Map.class, importParams);
} catch (Exception e) {
e.printStackTrace();
}
存在的問(wèn)題
- 導(dǎo)入相同列名依舊會(huì)有丟失數(shù)據(jù)的問(wèn)題,原因key重復(fù),目前好像沒(méi)找到解決辦法
- 遍歷時(shí)默認(rèn)map的值為空則不返回,通過(guò)設(shè)置setKeyIndex(null)可以解決該問(wèn)題
- 當(dāng)表頭存在多個(gè)的時(shí)候,遍歷的titlemap存在問(wèn)題,詳見(jiàn)issues
小結(jié)
總的來(lái)說(shuō),easypoi功能還是很強(qiáng)大,使用上也簡(jiǎn)單,主要是把數(shù)據(jù)結(jié)構(gòu)想清楚,之后的導(dǎo)入導(dǎo)出邏輯就很簡(jiǎn)單了,本文example 在GitHub上地址:easypoi-demo
到此這篇關(guān)于Java中easypoi導(dǎo)入excel文件列名相同的處理方案的文章就介紹到這了,更多相關(guān)Java 導(dǎo)入excel文件列名相同內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解析spring boot與ireport 整合問(wèn)題
本文通過(guò)實(shí)例代碼給大家介紹了spring boot 與 ireport 整合問(wèn)題,關(guān)于pom文件依賴(lài)的問(wèn)題通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-10-10
Java實(shí)現(xiàn)調(diào)用外部程序的示例代碼
本文主要介紹了Java實(shí)現(xiàn)調(diào)用外部程序的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
springboot訪(fǎng)問(wèn)靜態(tài)資源遇到的坑及解決
這篇文章主要介紹了springboot訪(fǎng)問(wèn)靜態(tài)資源遇到的坑及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
JAVA設(shè)計(jì)模式之備忘錄模式原理與用法詳解
這篇文章主要介紹了JAVA設(shè)計(jì)模式之備忘錄模式,簡(jiǎn)單說(shuō)明了備忘錄模式的概念、原理并結(jié)合實(shí)例形式分析了java備忘錄模式的具體定義及使用方法,需要的朋友可以參考下2017-08-08
Java實(shí)現(xiàn)格式化打印慢SQL日志的方法詳解
不管我們使用何種語(yǔ)言開(kāi)發(fā),一旦程序發(fā)生異常,日志是一個(gè)很重要的數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于Java實(shí)現(xiàn)格式化打印慢SQL日志的相關(guān)資料,需要的朋友可以參考下2022-10-10
nacos單機(jī)版啟動(dòng)失敗問(wèn)題以及解決
這篇文章主要介紹了nacos單機(jī)版啟動(dòng)失敗問(wèn)題以及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
spring cloud openfeign 源碼實(shí)例解析
這篇文章主要介紹了spring cloud openfeign 源碼實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10

