SpringBoot解析前端上传的Excel文件并导入数据库
创作时间:
作者:
@小白创作中心
SpringBoot解析前端上传的Excel文件并导入数据库
引用
CSDN
1.
https://blog.csdn.net/haduwi/article/details/111292886
一、准备工作
在开始解析Excel文件之前,需要在项目的pom.xml文件中添加Apache POI的相关依赖,以便能够解析Excel文件。
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.0.1</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.0.1</version>
</dependency>
此外,还需要准备一份Excel模板和相应的SQL数据库表。
二、优化点
为了提高代码的复用性和灵活性,将ExcelUtil工具类定义为泛型类。这样,ExcelUtil就可以解析任何Excel文件,并将其封装到相应的实体类中,最后将数据插入数据库。这种设计使得一个解析工具可以多次复用。
三、代码实现
1. Controller层
在Controller层,通过@PostMapping注解处理文件上传请求。使用MultipartFile接收上传的文件,并调用Service层的方法进行解析和导入数据库。
@PostMapping("/uploadExcel")
public Msg uploadExcel(@RequestParam("file") MultipartFile file) throws IOException {
String fileName = file.getOriginalFilename(); // 获取文件名
InputStream is = null;
try {
is = file.getInputStream();
List<Map> studentList = studentService.getListByExcel(is, fileName); // 获取解析后的List集合
Boolean result = studentService.batchImportStuInfo(studentList); // 把数据插入数据库
if (result) {
return Msg.success().add("info", "文件上传成功!");
} else {
return Msg.failure().add("info", "文件上传失败!");
}
} catch (Exception e) {
e.printStackTrace();
} finally {
is.close();
}
return Msg.failure().add("info", "文件错误!");
}
2. Service层
在Service层,定义了两个主要方法:getListByExcel用于解析Excel文件,batchImportStuInfo用于批量导入数据到数据库。
public List<Map> getListByExcel(InputStream is, String fileName) throws IOException {
try {
List<Map> studentList = new ExcelUtil<>(new Student()).AnalysisExcel(is, fileName);
return studentList;
} catch (Exception e) {
e.printStackTrace();
}
return new ArrayList<>();
}
public Boolean batchImportStuInfo(List<Map> list) {
Integer flag = studentMapper.batchImportStuInfo(list);
if (flag > 0) {
return true;
} else return false;
}
3. Mapper层
Mapper层定义了一个接口,用于批量导入学生信息。
@Repository
@Mapper
public interface StudentMapper {
// 批量导入学生信息
Integer batchImportStuInfo(List<Map> studentList);
}
4. ExcelUtil工具类
ExcelUtil工具类是整个实现的核心,它使用泛型来解析Excel文件并将其封装到指定的实体类中。
public class ExcelUtil<T> {
private T t;
public ExcelUtil(T t) {
this.t = t;
}
public List<Map> AnalysisExcel(InputStream is, String fileName) throws IOException {
List<Map> list = new ArrayList<>();
Workbook workbook = createWorkbookByExcelType(is, fileName); // 创建工作簿
Sheet sheet = workbook.getSheetAt(0);
Row row = null;
int maxRowNum = sheet.getLastRowNum();
row = sheet.getRow(0);
int maxColNum = row.getLastCellNum();
List<String> arrayList = new ArrayList<>();
Field[] declaredFields = t.getClass().getDeclaredFields();
for (int i = 0; i < declaredFields.length; i++) {
String name = declaredFields[i].getName();
arrayList.add(name);
}
for (int i = 0; i <= maxRowNum; i++) {
Map<String, String> map = new HashMap<>();
row = sheet.getRow(i);
if (row != null) {
for (int j = 0; j < maxColNum; j++) {
String cellData = (String) getCellFormatValue(row.getCell(j));
map.put(arrayList.get(j), cellData);
}
list.add(map);
}
}
return list;
}
public static Workbook createWorkbookByExcelType(InputStream inputStream, String fileName) {
Workbook wb = null;
if (fileName == null) {
return null;
}
String extString = fileName.substring(fileName.lastIndexOf("."));
InputStream is = null;
try {
is = inputStream;
if (".xls".equals(extString)) {
return wb = new HSSFWorkbook(is);
} else if (".xlsx".equals(extString)) {
return wb = new XSSFWorkbook(is);
} else {
return wb = null;
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return wb;
}
public static Object getCellFormatValue(Cell cell) {
Object cellValue = null;
if (cell != null) {
switch (cell.getCellType()) {
case NUMERIC:
cellValue = String.valueOf(cell.getNumericCellValue());
break;
case FORMULA:
if (DateUtil.isCellDateFormatted(cell)) {
cellValue = cell.getDateCellValue();
} else {
cellValue = String.valueOf(cell.getNumericCellValue());
}
break;
case STRING:
cellValue = cell.getRichStringCellValue().getString();
break;
default:
cellValue = "";
}
} else {
cellValue = "";
}
return cellValue;
}
}
5. Mapper.xml映射文件
在Mapper.xml文件中,定义了批量插入数据的SQL语句。
<insert id="batchImportStuInfo" parameterType="java.util.List">
insert into student values
<foreach item="item" collection="list" separator=",">
(
#{item.id},
#{item.stuName},
#{item.sex},
#{item.cardId},
#{item.stuId},
#{item.political},
#{item.major},
#{item.classGrade},
#{item.tel},
#{item.stuStatus}
#{item.city}
)
</foreach>
</insert>
6. application.yml配置文件
在application.yml文件中,配置了文件上传的大小限制。
spring:
servlet:
multipart:
max-file-size: 1000MB
max-request-size: 1000MB
四、代码分析
MultipartFile是Spring框架下的一个类,主要用于处理文件上传功能。它允许以表单的形式上传文件,是Spring项目中处理文件上传的常用方式。
五、效果展示
热门推荐
红糖姜枣茶的功效与作用与禁忌
大学绩点有什么用?对毕业有影响吗?
如何评估黄金的重量单位及其价值?不同重量单位的黄金价值如何换算?
如何选择适合的高端住宅?高端住宅的标准是什么?
校园霸凌的可怕真相:多数孩子不敢告诉父母,6大信号常被忽视!
盘点名著里的疯狂爱情:从《呼啸山庄》到《霍乱时期的爱情》
镝灯(HMI)在影视创作、工业照明领域应用广泛 我国供应能力不断增强
全球热榜第一的《鱿鱼游戏2》,为何跌落神坛?
上海楼市高热度背后:买家加速入场 一二手房走出独立行情
口腔溃疡可以按揉什么穴位
小宝爱抠脚?难道是天生的?
心脏超声-EF-计算公式及评估方法
汽车兵的"飞驰人生"!
疼痛拜拜:牙髓炎属于几级疼痛?4-7级疼痛!可服用药物/冰敷等减轻疼痛!
认识国防动员的基本内涵
焊接知识——“屈服强度”详解
全球金融科技中心TOP5城市差距缩小,人工智能等金融科技B端应用成为“新胜负手”
揭秘主板BIOS:功能详解与故障解决指南
福建南平:解锁稻烟协同的生态密码
科学家用全身分子图谱显示为什么运动对你的健康有益
“抱歉鲁迅先生,这真不是人为的”,北方校园雕塑被“大雪”玩坏
狗狗可以吃鹰嘴豆吗?营养与风险全解析
岁月传承谱写运河文化新章!《北上》今晚CCTV-1黄金档开播
评今年的金棕榈电影《阿诺拉》
印度"硅谷"班加罗尔面临缺水危机,科技企业另觅他处
欧洲古典柱式:多立克、爱奥尼、科林斯、塔司干、复合柱式
深蹲跳的好处(深蹲瘦腿还是粗腿)
汇率决定理论解析:影响汇率变动的关键因素
央企红利、国企红利、民企红利三只红利指数的简单对比分析
智齿疼和牙龈疼有什么区别?怎么判断智齿疼还是牙龈疼?