导出列表数据到Excel并下载

Java导出查询到的数据列表为Excel并下载

1.背景

工作中经常有需求,需要把列表的数据导出为Excel并下载。EasyExcel工具可以很好的实现这一需求。

2.实现流程

1.引入EasyExcel依赖包

bash 复制代码
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>3.3.2</version>
</dependency>

2.创建实体VO,添加需要导出的字段并添加注释(根据自己需求创建)

java 复制代码
public class UserExcelVo {
    @ExcelProperty(value = "用户Id")
    private String userId;
    
	@ExcelProperty(value = "用户名称")
    private String userName;

    @ExcelProperty(value = "操作时间")
    private String createTime;
}

3.数据库中查到的实体列表转换成VoList

如果字段有需要特殊处理的,需要调用set方法单独设置。

java 复制代码
List<UserExcelVo > userExcelVos = new ArrayList<>();
for (User user : list) {
   	 UserExcelVo userExcelVo = new UserExcelVo();
     BeanUtils.copyProperties(user,userExcelVo);
     userExcelVos.add(userExcelVo);
}

4.使用EasyExcel工具导出数据

java 复制代码
public void export(List<UserExcelVo > userExcelVos ,HttpServletResponse response){
        String fileName = "用户记录.xlsx";
        try {
            response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE);
            response.setHeader("Content-Disposition", "attachment; filename=" + URLEncoder.encode(fileName, "utf-8"));
            OutputStream outputStream =response.getOutputStream();
            EasyExcel.write(outputStream,UserExcelVo.class).sheet("用户记录").doWrite(userExcelVos);
        }catch (Exception e){
            log.error("导出用户记录失败,原因: {}",e.getMessage());
            throw new ServiceException("导出用户记录数据失败");
        }
    }

Controller层和业务层逻辑按自己需求完善,有更好的方法欢迎分享。

相关推荐
启山智软7 分钟前
【中大企业选择源码部署商城系统】
java·spring·商城开发
我真的是大笨蛋9 分钟前
深度解析InnoDB如何保障Buffer与磁盘数据一致性
java·数据库·sql·mysql·性能优化
怪兽源码37 分钟前
基于SpringBoot的选课调查系统
java·spring boot·后端·选课调查系统
恒悦sunsite44 分钟前
Redis之配置只读账号
java·redis·bootstrap
梦里小白龙1 小时前
java 通过Minio上传文件
java·开发语言
人道领域1 小时前
javaWeb从入门到进阶(SpringBoot事务管理及AOP)
java·数据库·mysql
sheji52611 小时前
JSP基于信息安全的读书网站79f9s--程序+源码+数据库+调试部署+开发环境
java·开发语言·数据库·算法
毕设源码-邱学长1 小时前
【开题答辩全过程】以 基于Java Web的电子商务网站的用户行为分析与个性化推荐系统为例,包含答辩的问题和答案
java·开发语言
摇滚侠1 小时前
Java项目教程《尚庭公寓》java项目从开发到部署,技术储备,MybatisPlus、MybatisX
java·开发语言
€8112 小时前
Java入门级教程24——Vert.x的学习
java·开发语言·学习·thymeleaf·数据库操作·vert.x的路由处理机制·datadex实战