日常记录,使用springboot,vue2,easyexcel使实现字段的匹配导入

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

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

读取表头字段:

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

读Excel | Easy Excel 官网

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

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

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

设置前端展示的表头:

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

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

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

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

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

java 复制代码
            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,然后对日期进行解析。

相关推荐
niucloud-admin7 小时前
JAVA V6 多商户商城 开发文档——插件安装
java·开发语言
人道领域7 小时前
【黑马点评日记】RedisGEO实战:黑马点评附近商铺功能
java·数据库·redis·adb
逸Y 仙X7 小时前
文章二十六:ElasticSearch 异步查询执行重度任务
java·大数据·linux·运维·elasticsearch·搜索引擎·全文检索
洛阳泰山7 小时前
Maxkb4j集成sqlbot MCP实现企业智能问数智能体
java·ai·springboot·agent·智能问数
掘金者阿豪7 小时前
折腾了两天,终于把SQLAlchemy连上了金仓数据库
后端
SamDeepThinking8 小时前
RocketMQ消息可靠性的三道关卡
java·后端·程序员
Hesionberger8 小时前
LeetCode79:单词搜索DFS回溯详解
java·开发语言·c++·python·算法·leetcode·c#
skywalk81638 小时前
下载安装 Temurin® JDK JDK 21 - LTS 速度很慢,有办法加速吗?
java·开发语言
Mr数据杨8 小时前
【Codex】用PPT文案额外描述优化课件生成细节
java·javascript·django·powerpoint·codex·项目开发
Andya_net9 小时前
AI | CC GUI 集成 IDEA 完整教程
java·人工智能·intellij-idea