java 导出数据格式为csv


解决方案:

引入pom文件


<dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-csv</artifactId>
            <version>1.8</version>
</dependency>

示例代码:

@GetMapping("/N042")
public CommonResult N042(HttpServletResponse response, @RequestParam("qs") Date qs,
                         @RequestParam("zs") Date zs) {
    try (Connection conn = DriverManager.getConnection(url, username, password);
         CallableStatement cs = conn.prepareCall("{call PRO_N042(?,?)}");) {
        // 设置输入参数的值
        cs.setDate(1, qs);
        cs.setDate(2, zs);
        // 调用存储过程
        cs.execute();
        ResultSet resultSet = cs.executeQuery();

        // 创建CSV文件
        File csvFile = new File("N042.csv");
        FileWriter writer = new FileWriter(csvFile);
        CSVPrinter csvPrinter = new CSVPrinter(writer, CSVFormat.DEFAULT);

        // 获取ResultSet的元数据
        ResultSetMetaData metaData = resultSet.getMetaData();
        int columnCount = metaData.getColumnCount();

        // 将列名写入CSV文件
        for (int i = 1; i <= columnCount; i++) {
            csvPrinter.print(metaData.getColumnName(i));
        }
        csvPrinter.println();

        // 将数据写入CSV文件
        while (resultSet.next()) {
            for (int i = 1; i <= columnCount; i++) {
                csvPrinter.print(resultSet.getString(i));
            }
            csvPrinter.println();
        }

        csvPrinter.close();
        writer.close();

        // 设置响应头信息
        response.setContentType("text/csv");
        response.setHeader("Content-Disposition", "attachment; filename=\"" + csvFile.getName() + "\"");

        // 将CSV文件写入响应流中
        FileInputStream fileInputStream = new FileInputStream(csvFile);
        OutputStream outputStream = response.getOutputStream();
        byte[] buffer = new byte[1024];
        int bytesRead;
        while ((bytesRead = fileInputStream.read(buffer)) != -1) {
            outputStream.write(buffer, 0, bytesRead);
        }
        outputStream.flush();
        outputStream.close();
        fileInputStream.close();

        // 删除临时CSV文件
        csvFile.delete();

    } catch (SQLException | IOException e) {
        return CommonResult.error(e.getMessage());
    }
    return CommonResult.success();
}

这段代码使用了CSVPrinter和CSVFormat来创建和写入CSV文件。在将文件写入响应流之后,会删除临时的CSV文件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

海海向前冲

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

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

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

打赏作者

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

抵扣说明:

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

余额充值