SpringBoot结合easypoi.excel,实现数据导出Excel

大多数业务项目中必然会遇到的一个需求,导出数据文件---Excel。

这里简单贴一下自己开发使用的方式方法,抛砖引玉。

也可小白直接大胆食用。

功能Maven依赖:

XML 复制代码
<dependency>
   <groupId>cn.afterturn</groupId>
   <artifactId>easypoi-base</artifactId>
   <version>4.5.0</version>
</dependency>
<dependency>
   <groupId>cn.afterturn</groupId>
   <artifactId>easypoi-web</artifactId>
   <version>4.5.0</version>
</dependency>
<dependency>
   <groupId>cn.afterturn</groupId>
   <artifactId>easypoi-annotation</artifactId>
    <version>4.5.0</version>
</dependency>

业务入口controller,这里很简单

java 复制代码
@GetMapping("/exportApply")
    public void exportApply(BusBasicFlowQuery query, HttpServletResponse response,
                            @RequestHeader(required = false) String lang) throws IOException {
        query.setSize(20000);
        // query:这里就是个查询条件,根据个人业务实操就行
        // 这里就是根据业务需求查询出想要导出的数据集合信息
        // 重点说明一下:Bd3OrderExcel里面包好你要导出的表格列说明
        List<Bd3OrderExcel> bd3OrderExcelList = busBasicFlowService.exportApply(query, lang);
        ExportParams exportParams = new ExportParams();
        ExcelUtils.exportExcel(response, "北三卡申请", bd3OrderExcelList, Bd3OrderExcel.class, exportParams);
    }

重点说明一下Bd3OrderExcel,这个类注明的导出表格字段名称、顺序,宽度等。

java 复制代码
package com.rdss.bus.model.excel;

import cn.afterturn.easypoi.excel.annotation.Excel;
import lombok.Data;

import java.time.LocalDateTime;

@Data
public class Bd3OrderExcel {

    private Integer id;

    /**
     * 申请人身份证号
     */
    @Excel(name = "申请人姓名",width = 30.0)
    private String operatorName;
    /**
     * 申请时间
     */
    @Excel(name = "申请时间",format = "yyyy-MM-dd HH:mm:ss", databaseFormat="yyyy-MM-dd HH:mm:ss" ,width = 30.0)
    private LocalDateTime applyTime;
    /**
     * 申请原因
     */
    @Excel(name = "申请原因",width = 20.0)
    private String remark;
    /**
     * 申请人手机号
     */
    @Excel(name = "申请人手机号",width = 20.0)
    private String operatorMobile;
    /**
     * 申请人身份证号
     */
    @Excel(name = "申请人身份证号",width = 30.0)
    private String operatorIdcardNum;
    /**
     * 申请人邮箱
     */
    @Excel(name = "申请人邮箱",width = 30.0)
    private String operatorEmail;
    /**
     * 申请人机构
     */
    @Excel(name = "申请人机构",width = 30.0)
    private String operatorOrgName;

    /**
     * 审批结果(0-审核中,1-通过,2-不通过
     */
    @Excel(name = "一级审批状态",dict = "approval_result",width = 15.0)
    private String approveResult_first;

    /**
     * 审批人姓名
     */
    @Excel(name = "一级审批人姓名",width = 30.0)
    private String approveUserName_first;
}

导出封装工具类:

java 复制代码
import cn.afterturn.easypoi.excel.ExcelExportUtil;
import cn.afterturn.easypoi.excel.entity.ExportParams;
import com.rdss.bus.service.handler.DictHandler;
import lombok.extern.slf4j.Slf4j;
import org.apache.poi.ss.usermodel.Workbook;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;

import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;

/**
 * excel工具类
 */
@Slf4j
public class ExcelUtils {
    private ExcelUtils(){}

    @Autowired
    private static DictHandler dictHandler;
    /**
     * Excel导出
     *
     * @param response      response
     * @param fileName      文件名
     * @param list          数据List
     * @param pojoClass     对象Class
     */
    public static void exportExcel(HttpServletResponse response, String fileName, Collection<?> list, Class<?> pojoClass, ExportParams exportParams ) throws IOException {
        exportParams.setStyle(ExcelStyleUtil.class);
        Workbook workbook = ExcelExportUtil.exportExcel(exportParams, pojoClass, list);
        response.setCharacterEncoding("UTF-8");
        response.setHeader("content-Type", "application/vnd.ms-excel");
        response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName, "UTF-8") + ".xls");
        ServletOutputStream out = response.getOutputStream();
        workbook.write(out);
        out.flush();
    }

    /**
     * Excel导出,先sourceList转换成List<targetClass>,再导出
     *
     * @param response      response
     * @param fileName      文件名
     * @param sourceList    原数据List
     * @param targetClass   目标对象Class
     */
    public static void exportExcelToTarget(HttpServletResponse response, String fileName, Collection<?> sourceList,
                                     Class<?> targetClass) throws IllegalAccessException, InstantiationException, IOException {
        List<Object> targetList = new ArrayList<>(sourceList.size());
        for(Object source : sourceList){
            Object target = targetClass.newInstance();
            BeanUtils.copyProperties(source, target);
            targetList.add(target);
        }

        exportExcel(response, fileName, targetList, targetClass, new ExportParams());
    }
}
相关推荐
workflower3 小时前
单元测试-例子
java·开发语言·算法·django·个人开发·结对编程
YuanlongWang3 小时前
C# 基础——装箱和拆箱
java·开发语言·c#
摇滚侠3 小时前
Spring Boot 3零基础教程,WEB 开发 静态资源默认配置 笔记27
spring boot·笔记·后端
b78gb3 小时前
电商秒杀系统设计 Java+MySQL实现高并发库存管理与订单处理
java·开发语言·mysql
wb043072014 小时前
性能优化实战:基于方法执行监控与AI调用链分析
java·人工智能·spring boot·语言模型·性能优化
天若有情6735 小时前
Java Swing 实战:从零打造经典黄金矿工游戏
java·后端·游戏·黄金矿工·swin
lichong9516 小时前
Android studio 修改包名
android·java·前端·ide·android studio·大前端·大前端++
lichong9516 小时前
Git 检出到HEAD 再修改提交commit 会消失解决方案
java·前端·git·python·github·大前端·大前端++
@yanyu6666 小时前
Tomcat安装与HTML响应实战
java·tomcat·html
Chen-Edward7 小时前
有了Spring为什么还有要Spring Boot?
java·spring boot·spring