当前位置: 首页 > news >正文

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

目前的需求是数据库字段固定,而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,然后对日期进行解析。


http://www.mrgr.cn/news/58610.html

相关文章:

  • ES操作:linux命令
  • 【Flutter】水波纹扩散动画
  • 鸿蒙到底是不是纯血?到底能不能走向世界?
  • 理解 `super(...)` 和 `this(...)` 的区别
  • Vue 3项目的性能监测和优化
  • Python常见问题处理
  • bios设置后cpu虚拟化仍禁用
  • 通过ssh端口反向通道建立并实现linux系统的xrdp以及web访问
  • 《近似线性可分支持向量机的原理推导》 拉格朗日函数 公式解析
  • jupyter notebook改变默认启动路径
  • spring框架介绍
  • TCP simultaneous open测试
  • 【Linux系统】如何证明进程的独立性
  • Redis的RDB执行原理
  • [CSP-J 2023] 一元二次方程(模拟)
  • bitpoke- mysql-operator cluster
  • java 17天 TreeSet以及Collections
  • SSH 的 N 大黑科技玩法
  • LeetCode Hot 100:二分查找
  • Visual Studio中无法打开Qt中UI文件,简单快捷处理方法
  • Zookeeper客户端工具 Apache Curator 最佳实践
  • 10340 文本编辑器(vim)
  • Swift 是一种由苹果公司开发的强大而直观的编程语言,主要用于开发 iOS、macOS、watchOS 和 tvOS 等苹果平台的应用程序。
  • C++中如何使用文件系统路径
  • AcWing 89:a^b ← 快速幂
  • 136.只出现一次的数字