在实际项目开发中,对于Excel的导入导出还是很常见的需求,比如说将数据根据模板批量导入到数据库中,以及将数据库中的数据批量导出陈Excel的形式
现有需求:
下载固定的导入Excel模板
导入Excel中的数据进数据库
将数据进行Ecel导出
本篇文章,先总结excel静态模板文件的下载
一. 准备工作
准备静态文件
导入 EasyPOI 的依赖
1.7.9
4.1.0
cn.afterturn
easypoi-spring-boot-starter
${easypoi.version}
cn.afterturn
easypoi-base
${easypoi.version}
cn.afterturn
easypoi-web
${easypoi.version}
cn.afterturn
easypoi-annotation
${easypoi.version}
二. 使用easypoi进行静态模板的导出
excel静态模板下载,有两种方式:
第一种,在http头中指定输出文件流的类型为"application/vnd.ms-excel"类型时,输出流时就不需要添加输出文件的后缀名;
@GetMapping("/templateDownload")
public ResponseEntity templateDownload(@PathVariable("organizationId")Long tenantId,
HttpServletResponse response ) {
try {
// 获取资源中的模板文件
ClassPathResource resource = new ClassPathResource("static\\拉线-设备主数据导入模板.xlsx");
InputStream inputStream = resource.getInputStream();
Workbook wb = WorkbookFactory.create(inputStream);
String fileName="拉线-设备主数据导入模板";
response.setCharacterEncoding("UTF-8");
response.setHeader("content-Type", "application/vnd.ms-excel");
response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName, "UTF-8"));
wb.write(response.getOutputStream());
return Results.success();
}catch (IOException e){
return Results.error(e.getMessage());
}
第二种,指定文件流的类型为"multipart/form-data"时,输出流时需要判断文件是.xls/.xlsx,并且加上后缀名。
@GetMapping("/templateDownload1")
public ResponseEntity templateDownload1(@PathVariable("organizationId")Long tenantId,
HttpServletResponse response ) {
try {
// 获取资源中的模板文件
ClassPathResource resource = new ClassPathResource("static\\拉线-设备主数据导入模板.xlsx");
InputStream inputStream = resource.getInputStream();
// 根据不同excel创建不同对象,Excel2003版本-->HSSFWorkbook,Excel2007版本-->XSSFWorkbook
Workbook wb = WorkbookFactory.create(inputStream);
response.reset();
response.setContentType("multipart/form-data");
String fileName="拉线-设备主数据导入模板";
// 判断excel文件类型,下载获取到的模板并重新命名
System.out.println(wb.getClass().getSimpleName());
if (wb.getClass().getSimpleName().equals("HSSFWorkbook")) {
response.setHeader("Content-Disposition",
"attachment; filename=" + "attachment;filename=" + URLEncoder.encode(fileName, "UTF-8") + ".xls");
} else {
response.setHeader("Content-Disposition",
"attachment; filename=" + "attachment;filename=" + URLEncoder.encode(fileName, "UTF-8") + ".xlsx");
}
wb.write(response.getOutputStream());
return Results.success();
}catch (IOException e){
return Results.error(e.getMessage());
}
这部分我只是大概写了一下测试实现,在实际的工作中,导入导出等代码肯定是有特别高的复用率的,可以将代码中其中一部分抽离出来一个公用的工具类进行调用