Java使用csv导出大批量数据(二)

本文介绍了在Java中使用CSV导出大批量数据的注意事项,包括数据量评估、分页计算、服务器性能考虑以及导出时间需求的考量。通过分批读取避免OOM问题,并强调了根据机器配置和用户需求调整每批导出数据量的重要性。
摘要由CSDN通过智能技术生成

接着上一篇,这次将给大家呈现完整的内容,还是那句话,直接上代码:

package com.test.common.utils.csv;

import com.google.common.collect.Lists;
import com.test.common.exception.base.ServiceException;
import com.test.common.utils.DateUtils;
import com.test.framework.aspectj.lang.annotation.CSV;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.csv.CSVFormat;
import org.apache.commons.csv.CSVPrinter;
import org.springframework.util.CollectionUtils;

import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.lang.reflect.Field;
import java.nio.charset.StandardCharsets;
import java.util.*;
import java.util.stream.Collectors;

@Slf4j
public class CsvUtil<T> {

    private Class<T> clazz;

    public CsvUtil() {
    }

    public CsvUtil(Class<T> clazz) {
        this.clazz = clazz;
    }

    public Class<T> getClazz() {
        return clazz;
    }

    public void setClazz(Class<T> clazz) {
        this.clazz = clazz;
    }

    /**
     * 获取所有注解字段
     * @return
     */
    public List<Field> getHeader() {
        Class tempClass = this.clazz;
        List<Field> allFields = Lists.newArrayList();

        //获取父类上的fields,当父类为null的时候说明到达了最上层的父类(Object类).
        while (tempClass != null) {
            allFields.addAll
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值