当前位置: 首页 > article >正文

导出列表数据到Excel并下载

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

1.背景

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

2.实现流程

1.引入EasyExcel依赖包

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>3.3.2</version>
</dependency>

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

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

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

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

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

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

4.使用EasyExcel工具导出数据

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层和业务层逻辑按自己需求完善,有更好的方法欢迎分享。


http://www.kler.cn/a/374464.html

相关文章:

  • vscode摸鱼学习插件开发
  • ros中launch文件学习(3)
  • 臻于智境 安全护航 亚信安全受邀出席新华三智算新品发布会
  • vscode的一些使用心得
  • Chromium127编译指南 Linux篇 - 额外环境配置(五)
  • mac ssh 连接 linux 服务器
  • echarts 实现3D饼状图 加 label标签显示
  • Xcode 15.4 运行flutter项目,看不到报错信息详情?
  • 【Flask】四、flask连接并操作数据库
  • 深入理解跳出率:如何利用百度统计优化网站用户体验
  • redis的数据过期策略
  • 基于SSM演出道具租赁系统的设计
  • 初窥 HTTP 缓存
  • 完全透彻了解一个asp.net core MVC项目模板1
  • 【DBeaver】连接带kerberos的hive[Apache|HDP]
  • Rust 力扣 - 1456. 定长子串中元音的最大数目
  • 新品上市!让核酸酶质量和残留控制像测定蛋白浓度一样简单
  • C++20 时间转本地时间,时间转字符串以及字符串转时间的方法
  • 如何在Linux系统中使用Apache HTTP Server
  • 【测试工具篇一】全网最强保姆级教程抓包工具Fiddler(1)
  • Kaggle “Reducing Commercial Aviation Fatalities” 比赛 生理数据分析
  • [Web安全 网络安全]-提权、开发、对抗
  • 鸿蒙网络编程系列42-仓颉版域名解析示例
  • 【计算机科学】快速幂:指数运算的分治之美
  • 深度学习:Softmax 函数详解
  • C++基于opencv的视频质量检测--遮挡检测