欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

Easypoi是什么

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

開源地址:https://gitee.com/lemur/easypoi

獨特的功能

  • 基于注解的導(dǎo)入導(dǎo)出,修改注解就可以修改Excel
  • 支持常用的樣式自定義
  • 基于map可以靈活定義的表頭字段
  • 支持一堆多的導(dǎo)出,導(dǎo)入
  • 支持模板的導(dǎo)出,一些常見的標(biāo)簽,自定義標(biāo)簽
  • 支持HTML/Excel轉(zhuǎn)換,如果模板還不能滿足用戶的變態(tài)需求,請用這個功能
  • 支持word的導(dǎo)出,支持圖片,Excel

更多特性與功能詳解:easypoi官網(wǎng)說明

官方demo
官網(wǎng)實例工程:easypoi-test

導(dǎo)入

1. 指定模板導(dǎo)入

在導(dǎo)入指定Excel模板的過程中,可能會碰到列名重復(fù)的問題,當(dāng)我們使用Easypoi的注解方式進行導(dǎo)入時,會發(fā)現(xiàn)出現(xiàn)丟失數(shù)據(jù)的情況,原因是源碼在解析注解映射關(guān)系的時候,使用的map進行存儲,當(dāng)實體的注解存在相同名稱時,key會被重新覆蓋,導(dǎo)致數(shù)據(jù)列丟失,如圖通過添加fixedIndex屬性得以解決:

需要注意的是:fixedIndex是從0開始

Excel文件如圖:

2. Map自由導(dǎo)入

  ImportParams importParams = new ImportParams();
  importParams.setTitleRows(3);//標(biāo)題行
  importParams.setHeadRows(1);//表頭行
  importParams.setStartSheetIndex(0);//開始的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();
  }

存在的問題

  • 導(dǎo)入相同列名依舊會有丟失數(shù)據(jù)的問題,原因key重復(fù),目前好像沒找到解決辦法
  • 遍歷時默認(rèn)map的值為空則不返回,通過設(shè)置setKeyIndex(null)可以解決該問題
  • 當(dāng)表頭存在多個的時候,遍歷的titlemap存在問題,詳見issues

小結(jié)

總的來說,easypoi功能還是很強大,使用上也簡單,主要是把數(shù)據(jù)結(jié)構(gòu)想清楚,之后的導(dǎo)入導(dǎo)出邏輯就很簡單了,本文example 在GitHub上地址:easypoi-demo

到此這篇關(guān)于Java中easypoi導(dǎo)入excel文件列名相同的處理方案的文章就介紹到這了,更多相關(guān)Java 導(dǎo)入excel文件列名相同內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

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

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

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

    淺談Java為什么只能單繼承

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    SpringBoot中的自動裝配原理解析

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

最新評論