目前的需求是数据库字段固定,而excel的字段不固定,需要实现excel导入到一个数据库内。
首先是前端的字段匹配,显示数据库字段和表头字段
读取表头字段:
我这里实现的是监听器导入,需要新建一个listen类。
其中用到的主要方法(还有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,然后对日期进行解析。