您好,登錄后才能下訂單哦!
小編給大家分享一下如何處理Java中easypoi導(dǎo)入excel文件列名相同的問(wèn)題,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討方法吧!
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ú)特的功能
更多特性與功能詳解: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í)體的注解存在相同名稱時(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)題
看完了這篇文章,相信你對(duì)如何處理Java中easypoi導(dǎo)入excel文件列名相同的問(wèn)題有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。