Java编程

导航菜单



当前位置: 首页  /  Java基础  /  正文

SpringBoot动态生成多个Excel文件以压缩包.zip格式下载

阅读:1

SpringBoot动态生成多个Excel文件以压缩包.zip格式下载

来源:blog.csdn.net/qq_40437152/article/details/111411364


前言

文件下载的场景很多(还不是需求丰富嘛~),那么什么是动态生成文件呢,就是用户选择文件内容,服务器端根据选择的数据生成某个格式的文件然后下载到客户端。单个码直接下载,多个打包下载咯!

项目场景

项目中有个数据导出excel的需求,而且是批量,那么就要打包咯

解决步骤

基本实现如下:

  1. 生成文件
  2. 保存到临时目录 || 缓存到内存中
  3. 将文件打包下载

我不想废话了,上代码:

直接把文件输出流放到压缩流ZipOutputStream

 List<String> fields = new ArrayList<>();
        fields.add("字段1");
        fields.add("字段2");
        fields.add("字段3");
        HSSFWorkbook workbook = excelUtil.getNewExcel("压缩文件测试", fields);
        try {
            response.setContentType("application/zip; charset=UTF-8");
            //返回客户端浏览器的版本号、类型
            String agent = request.getHeader("USER-AGENT");
            String downloadName = "压缩文件测试.zip";
            //针对IE或者以IE为内核的浏览器:
            if (agent.contains("MSIE") || agent.contains("Trident")) {
                downloadName = java.net.URLEncoder.encode(downloadName, "UTF-8");
            } else {
                downloadName = new String(downloadName.getBytes("UTF-8"), "ISO-8859-1");
            }
            response.setHeader("Content-disposition", "attachment;filename=" + downloadName);
   
            ZipOutputStream zipOutputStream = new ZipOutputStream(response.getOutputStream());
   //多个从这里就可遍历了
   // --start
            ZipEntry entry = new ZipEntry("第一个文件名.xls");
            zipOutputStream.putNextEntry(entry);

            ByteOutputStream byteOutputStream = new ByteOutputStream();
            workbook.write(byteOutputStream);
            byteOutputStream.writeTo(zipOutputStream);
//            zipOutputStream.write(workbook.getBytes());
            byteOutputStream.close();
            zipOutputStream.closeEntry();
            // --end
            zipOutputStream.close();
        } catch (IOException e) {
            e.printStackTrace();
        }

生成excel文件也贴一下,如下:

public static HSSFWorkbook getNewExcel(String formName, List<String> fields) {
        //新建excel对象
        HSSFWorkbook workbook = new HSSFWorkbook();
        //新建工作表
        HSSFSheet sheet = workbook.createSheet(formName);
        // 设置表格默认列宽度为20个字节
        sheet.setDefaultColumnWidth((short) 20);
        // 生成一个样式
        HSSFCellStyle style = workbook.createCellStyle();
        // 生成一个字体
        HSSFFont font = workbook.createFont();
        font.setFontHeightInPoints((short) 12);
        //字体应用到当前样式
        style.setFont(font);
        //创建表格行
        HSSFRow row = sheet.createRow(0);
        //设置表单名称
        row.createCell(0).setCellValue(formName);
        if (fields.size() - 1 > 0) {
            //合并单元格
            sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, fields.size() - 1));
        }
        HSSFRow row1 = sheet.createRow(sheet.getLastRowNum() + 1);
        //设置列标题行
        for (int i = 0; i < fields.size(); i++) {
            row1.createCell(i).setCellValue(fields.get(i));
        }
        return workbook;
    }

一些实践总结,欢迎指正!

标签

SpringBoot动态生成多个Excel文件压缩包zip格式下载


相关文章列表

如何导出多个excel文件:简单易懂的导出教程 - SEO技巧

如何导出多个excel文件:简单易懂的导出教程 - SEO技巧

1、场景 数据量太大,excel单个sheet装不下,或者觉得慢——当然可以导出成txt,可是有些时候就被要求一定要是excel2、模板 3、依赖的jar参考前面的文章:java使用poi操作exce...


Java超级好用的Excel动态生成工具

Java超级好用的Excel动态生成工具

POI简介Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。开发工具及环境开发工具:IdeaJAVA版...


使用Java Poi库实现Excel文件加密、导出和下载功能

使用Java Poi库实现Excel文件加密、导出和下载功能

最终结果图poi依赖jar包 org.apache.poi poi 3...


Java实现简单易用的Excel文件读写,导出和下载Excel文件案例

Java实现简单易用的Excel文件读写,导出和下载Excel文件案例

EasyExcel组件EasyExcel是一个基于Java的简单、省内存的读写Excel的开源项目。在尽可能节约内存的情况下支持读写百M的Excel。 github地址:https://github....


一键转换Excel、CSV等格式文件数据至java对象,快速高效

一键转换Excel、CSV等格式文件数据至java对象,快速高效

在项目开发中,开发人员在编写代码过程中或多或少都要涉及到直接将固定格式的数据文件内容导入到系统中,例如将一个存放员工信息的Excel文件导入到系统中。以员工信息导入为例,大部分程序员的做法步骤如下:在...


使用 Spring Boot 实现向 Excel 模板写入数据并下载全过程

使用 Spring Boot 实现向 Excel 模板写入数据并下载全过程

之前用获取模板路径的方式测试没问题打包后就有问题了莫名出现一个! 找了很多教程尝试无果 最终使用下面这个方式无需获取file对象以及模板路径的方式进行写入下载(那个设置浏览器编码没有测试不知道能不能用...


友情链接