合理使用导出csv、excel方式

本文介绍了一种通过分页查询并导出CSV文件的方法,适用于结果集大小未知或可能非常大的场景。通过使用OpenCSV库,可以有效地避免内存溢出问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

合理使用导出csv、excel方式

  • 结果集不大,并且格式固定,可用poi、jxl等方式
  • 结果集无法估算大小,甚至有可能导致程序内存溢出,建议就直接用流的方式。将数据分页查询,再一页一页的写进流里,例子如下:

使用的jar包:

<dependency>
    <groupId>net.sf.opencsv</groupId>
    <artifactId>opencsv</artifactId>
    <version>2.3</version>
</dependency>

通用cvs导出方法
相关代码段:

/**
     * 输出CSV
     * @param response
     * @param pageInfo 分页参数
     * @param manager manager实例
     * @param methodName manager对应方法
     * @param cols 列名
     * @throws IOException
     */
    protected void writeCSV(HttpServletResponse response, PageInfo pageInfo, Object manager, String methodName, List<String[]> cols) throws IOException {
        try {
            response.setContentType("application/octet-stream");
            response.setCharacterEncoding("GBK");
            CSVWriter csvWriter = new CSVWriter(response.getWriter(), ',');

            Class cla = manager.getClass();
            Method m = cla.getDeclaredMethod(methodName, PageInfo.class);

            // 查出总记录数、列名
            int pageSize = pageInfo.getPageSize(); // 分页大小
            pageInfo.setPageNumber(1);
            pageInfo.setPageSize(1);
            Page page = (Page) m.invoke(manager, pageInfo);
            int totalNum = page.getTotalNumberOfElements(); // 总记录
            int lastPageNum = totalNum / pageSize +1; // 页数

            // 写列名到输出流 
            List<Object> objects = (List<Object>) page.getThisPageElements();
            if(null == objects || objects.size() < 1){
                return;
            }
            // 如果没有传入列名 默认用字段名
            if (cols == null) {
                cols = new ArrayList<String[]>();
                String[] strs = ObjectUtils.getFiledName(objects.get(0));
                cols.add(strs);
            } 
            csvWriter.writeAll(cols);

            // 将i页的记录写到输出流
            pageInfo.setPageSize(pageSize);
            List<String[]> strs = new ArrayList<String[]>();
            for (int i = 1; i <= lastPageNum; i++) {
                pageInfo.setPageNumber(i);
                page = (Page) m.invoke(manager, pageInfo);
                List<Object> objs = (List<Object>) page.getThisPageElements();
                strs = ObjectUtils.listObj2Strs(objs);
                csvWriter.writeAll(strs);
            }

            // 关闭输出流
            csvWriter.flush();
            csvWriter.close();
        } catch (Exception e) {
            log.error(e);
        }
    }

输出的csv:

idpkeypvaluedescription
402828c44105be98014105c2f8ab0002test1test2测试
ff8080814830f0af0148340d662c4fd2test1test2测试
ff80808147812b9c014781a6af952557test1test2测试
ff8080814834bd24014837070fdd32cftest1test2测试
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值