代码编织梦想

目前的需求是数据库字段固定,而excel的字段不固定,需要实现excel导入到一个数据库内。

首先是前端的字段匹配,显示数据库字段和表头字段

读取表头字段:

我这里实现的是监听器导入,需要新建一个listen类。

读Excel | Easy Excel 官网

其中用到的主要方法(还有hasNext,doAfterAllAnalysed等):

  • invoke:按照每一行读取
  • invokeHead:读取第一行(表头)

将表头的字段返回给前端,同时我把后端的字段用数组写死在前端了(也可以后代传),

设置前端展示的表头:

按照前端写定的字段按顺序展示:

结果,我的表头是(0到31),排版没排好:

然后把前端对应的映射传给后端:

这里的fielMapping是自定义的一个map,因为我的excel表头是中文,而数据库是英文

后端通过反射,将值设置在映射的字段中,在invoke中遍历单元格实现

            for (Map.Entry<Integer, Cell> entry : rowMap.entrySet()) {
                Integer index = entry.getKey();
                ReadCellData<?> cellData = (ReadCellData<?>) entry.getValue();

                // 获取当前单元格的字符串值
                String cellValue = cellData.getStringValue();
//                System.out.println("索引: " + index + ", 单元格值: " + cellValue);
                // 获取当前列的表头名称
                String header = headers.get(index); // 从保存的表头中获取
//                System.out.println("表头: " + header);

                // 根据表头名称获取对应的字段名
                String fieldName = fieldMapping.get(header);
//                System.out.println("找到字段名: " + fieldName);

                if (fieldName != null) {
                    // 使用反射将值设置到实体类中
                    setFieldValue(data, fieldName, cellValue);
//                    System.out.println("已设置值: " + cellValue + " 到字段: " + fieldName);
                } else {
//                    System.out.println("未找到对应字段: " + cellValue);
                }
            }

setFieldValue是自己写的反射方法,因为我的字段有时间,要判断一下类型是否等于Date.Class,然后对日期进行解析。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/m0_63220670/article/details/143245292

Spring Boot + EasyExcel 导入导出,好用到爆,可以扔掉 POI 了-爱代码爱编程

一、EasyExcel EasyExcel是一个基于Java的简单、省内存的读写Excel的开源项目。在尽可能节约内存的情况下支持读写百M的Excel。 官方doc地址:https://www.yuque.com/easyexcel/doc/easyexcel EasyExcel优势 注解式自定义操作。 输入输出简单,提供输入输出过程的接口

使用VUE+SpringBoot+EasyExcel 整合导入导出数据-爱代码爱编程

使用VUE+SpringBoot+EasyExcel 整合导入导出数据 创建一个普通的maven项目即可 项目目录结构 1 前端 存放在resources/static 下 index.html <!DOCTYPE html> <html lang="en"> <head>

springboot 集成 easyexcel 3.x 优雅实现 excel 导入导出-爱代码爱编程

点击上方“芋道源码”,选择“设为星标” 管她前浪,还是后浪? 能浪的浪,才是好浪! 每天 10:33 更新文章,每天掉亿点点头发... 源码精品专栏  原创 | Java 2021 超神之路,很肝~中文详细注释的开源项目RPC 框架 Dubbo 源码解析网络应用框架 Netty 源码解析消息中间件 RocketMQ 源码解析

基于poi3.17使用easyexcel导出 含前后端_easyexcel导出前后端-爱代码爱编程

依赖导入 我使用的是2.2.7版本 springboot+vue(element-ui) 最底下贴一个poi3.17的导出 <!-- excel --> <dependency> <groupId>org.apache.poi</groupId> <artifac

springboot 整合 easyexcel 实现自由导入导出,太强了_spring boot 使用easyexcel实现导出-爱代码爱编程

在实际的业务系统开发过程中,操作 Excel 实现数据的导入导出基本上是个非常常见的需求。 之前,我们有介绍一款非常好用的工具:EasyPoi,有读者提出在数据量大的情况下,EasyPoi 会占用内存大,性能不够好,严重的

spring boot植物健康系统:绿色科技的突破-爱代码爱编程

3系统分析 3.1可行性分析 通过对本植物健康系统实行的目的初步调查和分析,提出可行性方案并对其一一进行论证。我们在这里主要从技术可行性、经济可行性、操作可行性等方面进行分析。 3.1.1技术可行性 本植物健康系统采用SSM

spring boot:植物健康监测的智能专家-爱代码爱编程

摘要 随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了植物健康系统的开发全过程。通过分析植物健康系统管理的不足,创建了一个计算机管理植物健康系统的方案。文章介绍了植物健康系统的系统

spring boot 注解大全:全面解析 spring boot 常用注解及其应用场景-爱代码爱编程

Spring Boot 注解大全:全面解析 Spring Boot 常用注解及其应用场景 简介 Spring Boot 是一个基于 Spring 框架的简化开发框架,它旨在简化 Spring 应用的初始搭建和开发过程

java版工程管理系统spring cloud+spring boot+mybatis实现工程管理系统源码-爱代码爱编程

在当今快速发展的建设行业中,工程项目管理软件作为项目管理的重要工具,正在发挥着越来越重要的作用。它通过集成多个功能模块,从建设工程项目管理组织建设、项目策划决策、规划设计、施工建设到竣工交付、总结评估、运维运营,实现对项目的全过程、全方位综合管理。本文将详细介绍工程项目管理软件的主要模块及其功能点,并概述其前端架构和涉及的关键技术。 一、核心模块与功能点

spring boot应用mongodb-爱代码爱编程

1. 添加 Maven 依赖 在 Spring Boot 项目中,引入 spring-boot-starter-data-mongodb 依赖: <dependencies> <!-- Mong