SpringBoot 整合EasyExcel 获取动态Excel列名

摘要:
导读最近负责消息网关,里面有个短信模板导入功能,因为不同模板编号对应不同参数,导入后的数据定时发送,涉及到Excel中列名不固定问题,于是想根据列名+值,组合成一个大JSON,具体代码如下。
导读

最近负责消息网关,里面有个短信模板导入功能,因为不同模板编号对应不同参数,导入后的数据定时发送,涉及到Excel中列名不固定问题,于是想根据列名+值,组合成一个大JSON,具体代码如下。

引入依赖

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>2.2.6</version>
        </dependency>
        <!--fastjson-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.76</version>
        </dependency>

Excel监听器

importcom.alibaba.excel.context.AnalysisContext;
importcom.alibaba.excel.event.AnalysisEventListener;
importcom.alibaba.fastjson.JSON;

import java.util.*;

/*** @Description:Excel监听器
 * @Author:chenyanbin
 * @Date:2021/4/28 下午3:36
 * @Versiion:1.0
 */

public class ExcelListener extends AnalysisEventListener<Map<Integer, String>>{
    //Excel数据
    private List<Map<Integer, Map<Integer, String>>>list;
    //Excel列名
    private Map<Integer, String> headTitleMap = new HashMap<>();

    publicExcelListener() {
        list = new ArrayList<>();
    }

    @Override
    public void invoke(Map<Integer, String>data, AnalysisContext context) {
        System.out.println("解析到一条数据:" +JSON.toJSONString(data));
        Map<Integer, Map<Integer, String>> map = new HashMap<>();
        map.put(context.readRowHolder().getRowIndex(), data);
        list.add(map);
    }

    @Override
    public voiddoAfterAllAnalysed(AnalysisContext context) {
        System.out.println("所有数据解析完成");
    }

    @Override
    public void invokeHeadMap(Map<Integer, String>headMap, AnalysisContext context) {
        headTitleMap =headMap;
    }

    public List<Map<Integer, Map<Integer, String>>>getList() {
        returnlist;
    }

    public void setList(List<Map<Integer, Map<Integer, String>>>list) {
        this.list =list;
    }

    public Map<Integer, String>getHeadTitleMap() {
        returnheadTitleMap;
    }

    public void setHeadTitleMap(Map<Integer, String>headTitleMap) {
        this.headTitleMap =headTitleMap;
    }
}

控制器

注:已经组装好动态列名数组,具体业务逻辑,需自行实现

importcom.alibaba.excel.EasyExcel;
importcom.alibaba.fastjson.JSON;
importcom.ybchen.springbooteasyexcel.listener.ExcelListener;
importorg.springframework.web.bind.annotation.RequestMapping;
importorg.springframework.web.bind.annotation.RestController;
importorg.springframework.web.multipart.MultipartFile;

importjava.io.IOException;
importjava.util.ArrayList;
importjava.util.HashMap;
importjava.util.List;
importjava.util.Map;

/*** @Description:
 * @Author:chenyanbin
 * @Date:2021/4/28 下午3:36
 * @Versiion:1.0
 */@RestController
public classDemoController {
    /*** 导入
     *
     * @paramfile
     * @throwsIOException
     */@RequestMapping(value = "import")
    public List<Object> importStudentInfos(MultipartFile file) throwsIOException {
        ExcelListener studentListener = newExcelListener();
        EasyExcel.read(file.getInputStream(), studentListener).sheet().doRead();
        List<Map<Integer, Map<Integer, String>>> list =studentListener.getList();
        Map<Integer, String> headTitleMap =studentListener.getHeadTitleMap();
        List<Map<String, String>> mapList = new ArrayList<>();
        for (int i = 0; i < list.size(); i++) {
            Map<Integer, Map<Integer, String>> integerMapMap =list.get(i);
            integerMapMap.forEach((k, l) ->{
                Map<String, String> map = new HashMap<>();
                l.forEach((y, z) ->{
                    map.put(headTitleMap.get(y), z);
                });
                mapList.add(map);
            });
        }
        System.out.println(mapList);
        System.out.println("=============================");
        System.out.println(JSON.toJSONString(mapList));
        return null;
    }
}

Excel模板

SpringBoot 整合EasyExcel 获取动态Excel列名第1张

演示

SpringBoot 整合EasyExcel 获取动态Excel列名第2张

免责声明:文章转载自《SpringBoot 整合EasyExcel 获取动态Excel列名》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Java 枚举 enum 详解jQuery以Post方式发送请求并获取返回的文件供下载!下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

EasySharding.EFCore 如何设计使用一套代码完成的EFCore Migration 构建Saas系统多租户不同业务需求且满足租户自定义分库分表、数据迁移能力?

下面用一篇文章来完成这些事情 多租户系统的设计单纯的来说业务,一套Saas多租户的系统,面临很多业务复杂性,不同的租户存在不同的业务需求,大部分相同的表结构,那么如何使用EFCore来完成这样的设计呢?满足不同需求的数据库结构迁移 这里我准备设计一套中间件来完成大部分分库分表的工作,然后可以通过自定义的Migration 数据库文件来迁移构建不同的租户数据...

SpringMVC上传视频等大文件

前言:因自己负责的项目(jetty内嵌启动的SpringMvc)中需要实现文件上传,而自己对java文件上传这一块未接触过,且对 Http 协议较模糊,故这次采用渐进的方式来学习文件上传的原理与实践。该博客重在实践。 一. Http协议原理简介 HTTP是一个属于应用层的面向对象的协议,由于其简捷、快速的方式,适用于分布式超媒体信息系统。它于1990年提出...

C# 获取程序运行时路径

Ø  前言 开发中,很多时候都需要获取程序运行时路径,比如:反射、文件操作等。.NET Framework 已经封装了这些功能,可以很方便的使用。 C# 中有很多类都可以获取程序运行时路径,我们没必要记住所有的,只需要记住常用的(其他了解即可),比如: 1.   System.AppDomain.CurrentDomain.BaseDirectory,获取...

Delphi声明Record变量后直接初始化

 TARec = record    A1: string;    A2: string;  end;   TBRec = record    A1: string;    A2: string;    ARec: TARec;  end;   PAppWindow = ^TAppWindow;  TAppWindow = Record    Width,...

HBase性能优化方法总结

4.1 HBase性能优化方法总结(一):表的设计 4.1.1 Pre-Creating Regions 默认情况下,在创建HBase表的时候会自动创建一个region分区,当导入数据的时候,所有的HBase客户端都向这一个region写数据,直到这个region足够大了才进行切分。一种可以加快批量写入速度的方法是通过预先创建一些空的regions,这样...

【PHP】你使用过redis做异步队列么,是怎么用的?有什么缺点?

Redis设计主要是用来做缓存的,但是由于它自身的某种特性使得它可以用来做消息队列。 它有几个阻塞式的API可以使用,正是这些阻塞式的API让其有能力做消息队列; 另外,做消息队列的其他特性例如FIFO(先入先出)也很容易实现,只需要一个list对象从头取数据,从尾部塞数据即可; Redis能做消息队列还得益于其list对象blpop brpop接口以及P...