如何把获取到的数据导出成 Excel 表格格式,通过 EasyExcel 实现数据导出Excel文件

首先需要把获取到的数据转化成List格式

然后通过创建ExcelWriter对象把List格式的数据写进去

最后设置文件格式后直接导出

java 复制代码
@Override
    public void dataSourceDownload(String progressId, HttpServletResponse response) {
        //从内存中获取数据,可换成读取数据库拿数据
        Element element = cache.get(progressId);

        Map objectValue = (Map) element.getObjectValue();
        List<DataAnalyseDto> exportList = (List<DataAnalyseDto>) objectValue.get("alreadyData");

        // 创建ExcelWriter对象
        ExcelWriter excelWriter = EasyExcel.write("DataAnalyse.xlsx", DataAnalyseDto.class).build();

        // 创建WriteSheet对象
        WriteSheet writeSheet = EasyExcel.writerSheet("分析数据").build();

        // 将数据写入Excel
        excelWriter.write(exportList, writeSheet);

        // 关闭ExcelWriter对象
        excelWriter.finish();

        // 设置为导出件格式为excel
//        response.setContentType("application/vnd.ms-excel");
//        response.setCharacterEncoding("utf-8");
        String filePrefix = "分析数据文件";
        try {
            // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
            String fileName = URLEncoder.encode(filePrefix, "UTF-8").replaceAll("\\+", "%20");
            //Content-disposition 的 attachment参数将文件作为附件下载
            response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");
            EasyExcel.write(response.getOutputStream(), DataAnalyseDto.class).sheet("模板").doWrite(exportList);
        } catch (Exception e) {
            log.error("下载文件失败!", e.getMessage());
        } finally {
            cache.remove(progressId);
        }
        log.info("下载数据大小为:{}", exportList.size());
    }
相关推荐
留不住丨晚霞几秒前
说说SpringBoot常用的注解?
java·开发语言
华科云商xiao徐7 分钟前
Java多线程爬虫动态线程管理实现
java·爬虫·数据挖掘
柒七爱吃麻辣烫16 分钟前
八股文系列-----SpringBoot自动配置的流程
java·spring boot·rpc
M1A120 分钟前
Java 面试系列第一弹:基础问题大盘点
java·后端·mysql
发仔12321 分钟前
Dubbo介绍及示例用法
java·dubbo
goxingman29 分钟前
关于使用idea打包的时候报错,Maven提示乱码java: �Ҳ�������
java·maven·intellij-idea
邓不利东2 小时前
Spring中过滤器和拦截器的区别及具体实现
java·后端·spring
草履虫建模2 小时前
Redis:高性能内存数据库与缓存利器
java·数据库·spring boot·redis·分布式·mysql·缓存
苹果醋32 小时前
Vue3组合式API应用:状态共享与逻辑复用最佳实践
java·运维·spring boot·mysql·nginx
Micro麦可乐3 小时前
Java常用加密算法详解与实战代码 - 附可直接运行的测试示例
java·开发语言·加密算法·aes加解密·rsa加解密·hash算法