溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何處理Java中easypoi導(dǎo)入excel文件列名相同的問(wèn)題

發(fā)布時(shí)間:2020-06-24 09:24:47 來(lái)源:億速云 閱讀:534 作者:清晨 欄目:開(kāi)發(fā)技術(shù)

小編給大家分享一下如何處理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ú)特的功能

  • 基于注解的導(dǎo)入導(dǎo)出,修改注解就可以修改Excel
  • 支持常用的樣式自定義
  • 基于map可以靈活定義的表頭字段
  • 支持一堆多的導(dǎo)出,導(dǎo)入
  • 支持模板的導(dǎo)出,一些常見(jiàn)的標(biāo)簽,自定義標(biāo)簽
  • 支持HTML/Excel轉(zhuǎn)換,如果模板還不能滿足用戶的變態(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í)體的注解存在相同名稱時(shí),key會(huì)被重新覆蓋,導(dǎo)致數(shù)據(jù)列丟失,如圖通過(guò)添加fixedIndex屬性得以解決:

如何處理Java中easypoi導(dǎo)入excel文件列名相同的問(wèn)題

需要注意的是:fixedIndex是從0開(kāi)始

Excel文件如圖:

如何處理Java中easypoi導(dǎo)入excel文件列名相同的問(wèn)題

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

看完了這篇文章,相信你對(duì)如何處理Java中easypoi導(dǎo)入excel文件列名相同的問(wèn)題有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI