Springboot集成Hutool导出CSV的方法
作者:彭于晏Yan
文章介绍了如何引入依赖、使用CSV工具类以及实现接口的相关内容,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
1. 引入依赖
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.8.11</version>
</dependency>2. CSV工具类
import cn.hutool.core.text.csv.CsvUtil;
import cn.hutool.core.text.csv.CsvWriter;
import lombok.extern.slf4j.Slf4j;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.lang.reflect.Field;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;
import java.util.List;
import java.util.Map;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;
@Slf4j
public class CsvUtils {
public static <T> void export(HttpServletResponse response, String fileName, List<T> dataList) throws IOException {
// 设置响应内容类型
response.setContentType("text/csv");
response.setCharacterEncoding(StandardCharsets.UTF_8.name());
fileName = URLEncoder.encode(fileName, StandardCharsets.UTF_8);
response.setHeader("Content-Disposition", "attachment;filename=\"" + fileName + ".csv\"");
try (OutputStream out = response.getOutputStream();
OutputStreamWriter writer = new OutputStreamWriter(out, StandardCharsets.UTF_8)) {
// 写入UTF-8 BOM,帮助Notepad识别
writer.write("\uFEFF");
// 使用HuTool的CsvWriter
CsvWriter csvWriter = CsvUtil.getWriter(writer);
for (T data : dataList) {
String[] row = convertToRow(data);
csvWriter.write(row);
}
// 确保所有数据写入输出流
csvWriter.flush();
}
}
public static <T> void exportZip(HttpServletResponse response, Map<Integer, List<T>> dataLists) throws IOException {
// 设置响应内容类型
response.setContentType("application/zip");
response.setCharacterEncoding(StandardCharsets.UTF_8.name());
String zipFileName = URLEncoder.encode("地区结果.zip", StandardCharsets.UTF_8);
response.setHeader("Content-Disposition", "attachment;filename=\"" + zipFileName + "\"");
// 创建ZIP输出流
try (OutputStream out = response.getOutputStream();
ZipOutputStream zipOut = new ZipOutputStream(out, StandardCharsets.UTF_8)) {
for (Map.Entry<Integer, List<T>> listEntry : dataLists.entrySet()) {
Integer fileName = listEntry.getKey();
List<T> dataList = listEntry.getValue();
// 创建ZIP条目
ZipEntry zipEntry = new ZipEntry(fileName + ".csv");
zipOut.putNextEntry(zipEntry);
// 创建CSV写入器
OutputStreamWriter writer = new OutputStreamWriter(zipOut, StandardCharsets.UTF_8);
writer.write("\uFEFF");
CsvWriter csvWriter = CsvUtil.getWriter(writer);
// 写入数据
for (T data : dataList) {
String[] row = convertToRow(data);
csvWriter.write(row);
}
csvWriter.flush(); // 确保所有数据写入输出流
zipOut.closeEntry(); // 关闭当前条目
}
}
}
private static <T> String[] convertToRow(T data) {
Field[] fields = data.getClass().getDeclaredFields();
String[] row = new String[fields.length];
try {
for (int i = 0; i < fields.length; i++) {
// 设置字段可访问
fields[i].setAccessible(true);
// 获取字段值
Object value = fields[i].get(data);
// 转换为字符串,处理null
row[i] = value != null ? value.toString() : "";
}
} catch (IllegalAccessException e) {
log.error("数据转换异常:{}",e.getMessage());
}
return row;
}
}3. 接口
@Slf4j
@RestController
public class RegionExportController {
@SneakyThrows
@PostMapping("/api/v1/regionExport")
public void exportVehicleResult(HttpServletResponse response) {
// 模拟数据
List<RegionImportDTO> list = RegionImportDTO.exportData();
CsvUtils.export(response, "区域结果表", list);
}
@SneakyThrows
@PostMapping("/api/v1/regionExportZip")
public void exportZipVehicleResult(HttpServletResponse response) {
// 模拟数据
List<RegionImportDTO> list = RegionImportDTO.exportData();
Map<Integer, List<RegionImportDTO>> listMap = list.stream().collect(Collectors.groupingBy(RegionImportDTO::getType));
CsvUtils.exportZip(response, listMap);
}
}到此这篇关于Springboot集成Hutool导出CSV的方法的文章就介绍到这了,更多相关Springboot Hutool导出CSV内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
- SpringBoot3整合Hutool-captcha实现图形验证码
- Springboot整合hutool验证码的实例代码
- 基于SpringBoot和Hutool工具包实现验证码的案例
- SpringBoot集成Hutool防止XSS攻击的两种解决方法
- SpringBoot使用hutool-captcha实现验证码生成与验证
- SpringBoot整合Hutool实现文件上传的使用示例
- SpringBoot 项目使用hutool 工具进行 http 接口调用的处理方法
- springboot vue接口测试HutoolUtil TreeUtil处理树形结构
- SpringBoot+Hutool+thymeleaf完成导出Excel的实现方法
- Vue2+SpringBoot实现数据导出到csv文件并下载的使用示例
