亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java中easypoi導(dǎo)入excel文件列名相同的處理方案

 更新時(shí)間:2020年06月23日 14:55:47   作者:rockychen  
這篇文章主要介紹了Java中easypoi導(dǎo)入excel文件列名相同的處理方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

Easypoi是什么

Easypoi 功能如同名字easy,主打的功能就是容易,讓一個(gè)沒(méi)接觸過(guò)poi的人員,就可以方便的寫出Excel導(dǎo)出、Excel模板導(dǎo)出、Excel導(dǎo)入、Word模板導(dǎo)出,通過(guò)簡(jiǎn)單的注解和模板語(yǔ)言(熟悉的表達(dá)式fe語(yǔ)法),完成以前復(fù)雜的寫法

開(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屬性得以解決:

需要注意的是: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)文章

  • springboot掃描自定義的servlet和filter代碼詳解

    springboot掃描自定義的servlet和filter代碼詳解

    本文是一篇根據(jù)作者工作經(jīng)歷總結(jié)出來(lái)的關(guān)于springboot掃描自定義的servlet和filter代碼詳解的文章,小編覺(jué)得非常不錯(cuò),這里給大家分享下,和朋友們一起學(xué)習(xí),進(jìn)步。
    2017-10-10
  • 淺談Java為什么只能單繼承

    淺談Java為什么只能單繼承

    本文主要介紹了Java為什么只能單繼承,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • maven工程打包引入本地jar包的實(shí)現(xiàn)

    maven工程打包引入本地jar包的實(shí)現(xiàn)

    我們需要將jar包發(fā)布到一些指定的第三方Maven倉(cāng)庫(kù),本文主要介紹了maven工程打包引入本地jar包的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02
  • Java線程創(chuàng)建的四種方式總結(jié)

    Java線程創(chuàng)建的四種方式總結(jié)

    這篇文章主要介紹了Java線程創(chuàng)建的四種方式,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • 被kafka-client和springkafka版本坑到自閉及解決

    被kafka-client和springkafka版本坑到自閉及解決

    這篇文章主要介紹了被kafka-client和springkafka版本坑到自閉及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • springboot接收日期類型參數(shù)的操作方法

    springboot接收日期類型參數(shù)的操作方法

    如果使用Get請(qǐng)求,直接使用對(duì)象接收,則可以使用@DateTimeFormat注解進(jìn)行格式化,本文重點(diǎn)給大家介紹springboot接收日期類型參數(shù)的方法,感興趣的朋友一起看看吧
    2024-02-02
  • 淺談java中對(duì)集合對(duì)象list的幾種循環(huán)訪問(wèn)

    淺談java中對(duì)集合對(duì)象list的幾種循環(huán)訪問(wèn)

    下面小編就為大家?guī)?lái)一篇java中對(duì)集合對(duì)象list的幾種循環(huán)訪問(wèn)詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-07-07
  • IDEA中已配置阿里鏡像但maven無(wú)法下載jar包的問(wèn)題及解決方法

    IDEA中已配置阿里鏡像但maven無(wú)法下載jar包的問(wèn)題及解決方法

    這篇文章主要介紹了IDEA中已配置阿里鏡像但maven無(wú)法下載jar包的問(wèn)題,本文給大家分享解決方法,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • 一文搞懂Spring中的注解與反射

    一文搞懂Spring中的注解與反射

    這篇文章主要為大家介紹了Spring中的注解與反射的原理與實(shí)現(xiàn),文中的示例代碼講解詳細(xì),對(duì)我們了解Spring有一定的幫助,需要的可以參考一下
    2022-06-06
  • SpringBoot中的自動(dòng)裝配原理解析

    SpringBoot中的自動(dòng)裝配原理解析

    這篇文章主要介紹了SpringBoot中的自動(dòng)裝配原理解析,自動(dòng)裝配就是指 Spring 容器在不使用<constructor-arg>和<property>標(biāo)簽的情況下,可以自動(dòng)裝配(autowire)相互協(xié)作的Bean之間的關(guān)聯(lián)關(guān)系,將一個(gè) Bean注入其他Bean的Property中,需要的朋友可以參考下
    2023-08-08

最新評(píng)論