广告位联系
返回顶部
分享到

SpringBoot将多个Excel打包下载的实现

java 来源:互联网 作者:佚名 发布时间:2024-12-23 21:47:53 人浏览
摘要

在Spring Boot应用中,如果你需要将多个Excel文件打包成一个ZIP文件并提供下载,你可以使用一些Java库来帮助完成这个任务。这里我将展示如何使用Apache POI来生成Excel文件,以及使用Java.util.zip来

在Spring Boot应用中,如果你需要将多个Excel文件打包成一个ZIP文件并提供下载,你可以使用一些Java库来帮助完成这个任务。这里我将展示如何使用Apache POI来生成Excel文件,以及使用Java.util.zip来创建ZIP文件,并通过Spring Boot的控制器提供下载功能。

一、实现思路:

1.引入Apache POI坐标,用来生成Excel文件,引入Java.util.zip用来创建ZIP文件。

2.使用Apache POI将导出的Excel构造成byte[]。

3.使用util.zip将多个byte[]输出成压缩包。

二、实现步骤:

1. 添加依赖

首先,在你的pom.xml中添加必要的依赖:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

<dependencies>

    <!-- Spring Boot Web -->

    <dependency>

        <groupId>org.springframework.boot</groupId>

        <artifactId>spring-boot-starter-web</artifactId>

    </dependency>

 

    <!-- Apache POI for Excel generation -->

    <dependency>

        <groupId>org.apache.poi</groupId>

        <artifactId>poi-ooxml</artifactId>

        <version>5.2.3</version> <!-- 请检查最新版本 -->

    </dependency>

</dependencies>

2. 创建Excel文件

假设你已经有方法来生成Excel文件,如果没有,可以参考以下示例代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

import org.apache.poi.ss.usermodel.*;

import org.apache.poi.xssf.usermodel.XSSFWorkbook;

 

import java.io.ByteArrayOutputStream;

import java.io.IOException;

import java.util.List;

 

public class ExcelGenerator {

 

    public static byte[] generateExcel(List<String[]> data) throws IOException {

        Workbook workbook = new XSSFWorkbook();

        Sheet sheet = workbook.createSheet("Sheet1");

 

        int rowNum = 0;

        for (String[] rowData : data) {

            Row row = sheet.createRow(rowNum++);

            int colNum = 0;

            for (String cellData : rowData) {

                Cell cell = row.createCell(colNum++);

                cell.setCellValue(cellData);

            }

        }

 

        try (ByteArrayOutputStream out = new ByteArrayOutputStream()) {

            workbook.write(out);

            return out.toByteArray();

        } finally {

            workbook.close();

        }

    }

}

3. 创建ZIP文件

使用java.util.zip来创建包含多个Excel文件的ZIP文件:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

import org.springframework.http.HttpHeaders;

import org.springframework.http.HttpStatus;

import org.springframework.http.MediaType;

import org.springframework.http.ResponseEntity;

import org.springframework.web.bind.annotation.GetMapping;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RestController;

 

import javax.servlet.http.HttpServletResponse;

import java.io.*;

import java.util.List;

import java.util.zip.ZipEntry;

import java.util.zip.ZipOutputStream;

 

@RestController

@RequestMapping("/api/excel")

public class ExcelController {

 

    @GetMapping("/download-zip")

    public void downloadZip(HttpServletResponse response) throws IOException {

        // 设置响应头

        response.setContentType("application/zip");

        response.setHeader("Content-Disposition", "attachment; filename=excel_files.zip");

 

        // 创建ZIP输出流

        try (ZipOutputStream zos = new ZipOutputStream(response.getOutputStream())) {

            // 假设我们有多个Excel数据列表

            List<List<String[]>> excelDataList = getExcelDataLists(); // 你需要实现这个方法

 

            for (int i = 0; i < excelDataList.size(); i++) {

                List<String[]> excelData = excelDataList.get(i);

 

                // 生成Excel文件内容

                byte[] excelBytes = ExcelGenerator.generateExcel(excelData);

 

                // 创建ZIP条目

                ZipEntry entry = new ZipEntry("file" + (i + 1) + ".xlsx");

                zos.putNextEntry(entry);

 

                // 写入Excel文件到ZIP条目

                zos.write(excelBytes);

                zos.closeEntry();

            }

        }

    }

 

    private List<List<String[]>> getExcelDataLists() {

        // 返回模拟的数据列表

        // 这里你需要根据实际情况返回实际的数据

        return List.of(

                List.of(new String[]{"Header1", "Header2"}, new String[]{"Data1", "Data2"}),

                List.of(new String[]{"HeaderA", "HeaderB"}, new String[]{"DataA", "DataB"})

        );

    }

}

4. 测试

启动Spring Boot应用后,访问/api/excel/download-zip端点,应该会触发下载一个名为excel_files.zip的ZIP文件,其中包含了多个Excel文件。


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 :
相关文章
  • Maven管理多模块应用的统一版本号实现
    在大型项目中,尤其是涉及多个子模块的Maven项目,统一管理版本号是一个棘手的问题。尤其当项目的子模块多达几十个时,手动修改每个模
  • SpringBoot增量部署发布的实现

    SpringBoot增量部署发布的实现
    由于项目依赖的jar越来越多,Springboot默认的打包方式是将整个项目打包成一个jar包,每次发布时,打包后的jar越来越大,更新一个很小的功
  • SpringBoot将多个Excel打包下载的实现
    在Spring Boot应用中,如果你需要将多个Excel文件打包成一个ZIP文件并提供下载,你可以使用一些Java库来帮助完成这个任务。这里我将展示如何
  • SpringBoot事务传播机制介绍
    在 Spring Boot 开发中,事务是一个至关重要的概念,尤其是在涉及多层业务逻辑或者多个数据库操作时。Spring 提供了强大的事务管理功能,使
  • Java使用JNA调用DLL文件
    1、什么是JNA? JNA(Java Native Access)是一个在 Java 中调用本地代码的开源框架,提供了一种简单、高效的方式来访问本地动态链接库(如.d
  • Java8 CompletableFuture异步编程解读介绍

    Java8 CompletableFuture异步编程解读介绍
    CompletableFuturede介绍 Java 8 引入了 CompletableFuture 类,这是 Java 异步编程的一个重要进展。 CompletableFuture 提供了一种基于未来结果的异步编程模
  • 基于Maven pom文件使用分析
    project Maven 是一个强大的构建和依赖管理工具,pom.xml 文件是 Maven 项目的核心配置文件,用于定义项目的构建、依赖关系、插件、目标等。它
  • Java-URLDecoder、URLEncoder使用及说明介绍

    Java-URLDecoder、URLEncoder使用及说明介绍
    前言 Java中的URLDecoder和URLEncoder是用于对URL进行编码和解码的类。 URL编码是将URL中的特殊字符转换成特定的格式,以便于在URL中传递参数。
  • SpringBoot内置Tomcat启动方式

    SpringBoot内置Tomcat启动方式
    一、Tomcat相关配置类如何加载的? 在springboot项目中,我们只需要引入spring-boot-starter-web依赖,启动服务成功,我们一个web服务就搭建好了,
  • Springboot接收Get参数实践过程

    Springboot接收Get参数实践过程
    一、参数直接在路径中 1.假设请求地址是如下这种 RESTful 风格 hangge 这个参数值直接放在路径里面: http://localhost:8080/helloworld/张三 1 2 3 4 5
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计