SpringBoot如何使用easyexcel导出Excel呢?

乔欣 SpringBoot 发布时间:2023-03-20 20:32:13 阅读数:13901 1
下文笔者讲述SpringBoot使用easyexcel导出excel的方法分享,如下所示

SpringBoot运用easyexcel导出excel的方法

实现思路:
    1.引入easyexcel操作excel的jar包
	2.使用EasyExcel.write方法即可操作输出excel

引入依赖

<!--easyexcel,推荐使用2.0 以上版本,功能更加完善-->
<dependency>
	<groupId>com.alibaba</groupId>
	<artifactId>easyexcel</artifactId>
	<version>2.2.6</version>
</dependency>

创建模板VO类

@ExcelProperty(value = "导出excel表头的标题")
@ExcelIgnore:忽略这个字段,不导出这个字段的数据
@Data
public class UserExcelVo {
 
    @ExcelProperty(value = "姓名")
    private String username;
 
    @ExcelProperty(value = "手机号")
    private String mobile;
 
    @ExcelProperty(value = "创建时间")
    private String saveDate;
 
    /**
     * 忽略这个字段
     */
    @ExcelIgnore
    private String ignore;
 
}

导出Excel

/**
 * 导出用户模板
 * @param response
 * @throws Exception
 */
@RequestMapping(value = "/fileOutExcel", method = {RequestMethod.POST, RequestMethod.GET})
public void fileOutExcel(HttpServletResponse response) throws Exception {

	list<UserExcelVo> vos = new ArrayList<>();
	
	UserExcelVo userExcelVo= new UserExcelVo();
	userExcelVo.setUserName("测试");
	userExcelVo.setMobile("13800000000");
	userExcelVo.setSaveDate("2023.03.20 20:34");
	
	vos.add(userExcelVo);
	
	ExcelWrite.webWrite(response, "用户模板", UserExcelVo.class, "sheet1", vos );
}


//工具类

public class ExcelWrite {
 
   /**
     * 单sheet下载
     *
     * 文件下载并且失败的时候返回json(默认失败了会返回一个有部分数据的Excel)
     *
     * @since 2.1.1
     */
    public static  <T> void webWrite(HttpServletResponse response,
                 String fileName, Class c, 
                 String sheetName, List<T> data) throws IOException {
        // 这里注意 有反应使用swagger 会导致各种问题,请直接用浏览器或者用postman
        try {
            response.setContentType("application/vnd.ms-excel");
            response.setCharacterEncoding("utf-8");
            // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
            fileName = URLEncoder.encode(fileName, "UTF-8");
            response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");
            // 这里需要设置不关闭流
            EasyExcel.write(response.getOutputStream(), c).autoCloseStream(Boolean.FALSE).sheet(sheetName)
                    .doWrite(data);
        } catch (Exception e) {
            e.printStackTrace();
            // 重置response
            response.reset();
            response.setContentType("application/json");
            response.setCharacterEncoding("utf-8");
            Map<String, String> map = new HashMap<String, String>();
            map.put("code", "11");
            map.put("msg", "下载文件失败" + e.getMessage());
            response.getWriter().println(JSON.toJSONString(map));
        }
    }
}
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

本文链接: https://www.Java265.com/JavaFramework/SpringBoot/202303/6112.html

最近发表

热门文章

好文推荐

Java265.com

https://www.java265.com

站长统计|粤ICP备14097017号-3

Powered By Java265.com信息维护小组

使用手机扫描二维码

关注我们看更多资讯

java爱好者