springboot导出下载csv文件

首先效果图如下所示:数据从数据库查询出来之后导出成csv文件

csv文件其实就是将数据进行逗号分隔,但是csv文件还支持使用excel/wps 来打开,下面就是我使用excel打开后的数据格式:

其实总体实现还是比较简单的,就是将从数据库查询出来的数据写进csv的文件

其他就不多说了,下面直接上代码:

package com.example.txsmsboot.controller;

import com.example.txsmsboot.entity.Teacher;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.util.CollectionUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.io.ByteArrayOutputStream;
impor
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot导出CSV文件可以使用以下步骤: 1. 添加依赖 在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>com.opencsv</groupId> <artifactId>opencsv</artifactId> <version>5.5.2</version> </dependency> ``` 2. 创建CSV数据 可以使用Java集合或者数据库查询结果等数据源来创建CSV文件数据,例如: ```java List<String[]> data = new ArrayList<>(); data.add(new String[]{"Name", "Age", "Email"}); data.add(new String[]{"John Doe", "30", "john.doe@example.com"}); data.add(new String[]{"Jane Doe", "25", "jane.doe@example.com"}); ``` 3. 导出CSV文件 可以使用以下代码将数据导出CSV文件: ```java CsvWriter csvWriter = new CsvWriter(new FileWriter("data.csv"), CsvWriter.DEFAULT_SEPARATOR, CsvWriter.NO_QUOTE_CHARACTER); for (String[] rowData : data) { csvWriter.writeNext(rowData); } csvWriter.close(); ``` 其中,CsvWriter是opencsv库提供的CSV写入器,接受一个Writer对象作为参数,用于将数据写入文件中。 4. 下载CSV文件 可以使用Spring Boot的ResponseEntity来将CSV文件返回给客户端下载,例如: ```java @GetMapping("/download") public ResponseEntity<Resource> downloadCsvFile() throws IOException { File file = new File("data.csv"); InputStreamResource resource = new InputStreamResource(new FileInputStream(file)); HttpHeaders headers = new HttpHeaders(); headers.add(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=data.csv"); return ResponseEntity.ok() .headers(headers) .contentLength(file.length()) .contentType(MediaType.parseMediaType("application/octet-stream")) .body(resource); } ``` 其中,InputStreamResource是Spring的Resource接口的实现,用于将文件转换为InputStream对象。将其包装在ResponseEntity中返回给客户端即可。 完整示例代码: ```java import com.opencsv.CSVWriter; import org.springframework.core.io.InputStreamResource; import org.springframework.http.HttpHeaders; import org.springframework.http.MediaType; import org.springframework.http.ResponseEntity; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; import java.io.File; import java.io.FileInputStream; import java.io.FileWriter; import java.io.IOException; import java.util.ArrayList; import java.util.List; @Controller @RequestMapping("/csv") public class CsvController { @GetMapping("/export") @ResponseBody public ResponseEntity<Resource> exportCsvFile() throws IOException { List<String[]> data = new ArrayList<>(); data.add(new String[]{"Name", "Age", "Email"}); data.add(new String[]{"John Doe", "30", "john.doe@example.com"}); data.add(new String[]{"Jane Doe", "25", "jane.doe@example.com"}); CsvWriter csvWriter = new CsvWriter(new FileWriter("data.csv"), CsvWriter.DEFAULT_SEPARATOR, CsvWriter.NO_QUOTE_CHARACTER); for (String[] rowData : data) { csvWriter.writeNext(rowData); } csvWriter.close(); File file = new File("data.csv"); InputStreamResource resource = new InputStreamResource(new FileInputStream(file)); HttpHeaders headers = new HttpHeaders(); headers.add(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=data.csv"); return ResponseEntity.ok() .headers(headers) .contentLength(file.length()) .contentType(MediaType.parseMediaType("application/octet-stream")) .body(resource); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酒书

你的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值