SpringBoot整合Hutool实现Excel导入导出

1、添加依赖

在pom.xml文件中添加如下依赖:

<!-- 引入hutool依赖-->
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.8.5</version>
</dependency>
<!-- 引入Hutool-poi依赖,Hutool-poi是针对Apache POI的封装,Java针对MS Office的操作的库 -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.1.2</version>
</dependency>

2、简单配置使用

在controller中使用(ps:正常情况下应该在service层写逻辑,这里只做简单演示):

 //导出
@GetMapping("/export")
public void export(HttpServletResponse response) throws Exception{
//从数据库查询出所有数据
List<User> list = userService.list();
//通过工具类创建,写出到磁盘路劲
// ExcelWriter writer = ExcelUtil.getWriter(filesUploadPath + "/用户信息.xlsx");
//在内存操作写出到浏览器
ExcelWriter writer = ExcelUtil.getWriter(true);
//自定义表头别名,在实体类使用@Alias("邮箱")注解后就不用设置,导入导出都会将注解上的别名识别为表头名字。
// writer.addHeaderAlias("id","ID");
// writer.addHeaderAlias("username","用户名");
// writer.addHeaderAlias("password","密码");
// writer.addHeaderAlias("nickname","昵称");
// writer.addHeaderAlias("email","邮箱");
// writer.addHeaderAlias("phone","电话");
// writer.addHeaderAlias("address","地址");
// writer.addHeaderAlias("crateTime","创建时间");
// writer.addHeaderAlias("avatarUrl","头像");

//一次性写出list内对象到Excel,使用默认样式,强制输出标题
writer.write(list,true);

//设置浏览器响应的格式
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8");
String fileName = URLEncoder.encode("用户信息", "UTF-8");
response.setHeader("Content-Disposition","attachment;filename=" + fileName + ".xlsx");

ServletOutputStream out = response.getOutputStream();
writer.flush(out,true);
out.close();
writer.close();
}

//导入
@PostMapping("/import")
public Boolean imp(MultipartFile file) throws Exception{
InputStream inputStream = file.getInputStream();
ExcelReader reader = ExcelUtil.getReader(inputStream);
// 从表头开始读
List<User> list = reader.readAll(User.class);
// 跳过0行的表头,从1行开始读
// List<User> list = reader.read(0, 1, User.class);
System.out.println(list);
//将导入的数据写入数据库
boolean b = userService.saveBatch(list);
inputStream.close();
reader.close();
return b;
}

注意:在自定义表头别名哪里,如果不想在controller里写,可以再对应实体类的属性上添加@Alias(“xxx”)注解设置别名。但是使用@Alias注解后再使用BeanUtil.copyProperties(user,userDTO,true);//将查询的用户信息user复制给userDTO复制属性值时会失败,解决办法:

  1. 使用spring框架的BeanUtil工具类。
  2. 继续使用Hutool的BeanUtil类,然后在被赋值的类的属性上也通过@Alias注解设置对应相同的别名。

备注:Hutool官网