java - 使用 openCsv StatefulBeanToCSV 限制 CSV 文件大小

标签 java spring-boot csv opencsv supercsv

我有一个对象列表,比如说我从数据库获得的产品列表。我能够使用 openCSV StatefulBeanToCSV writer 将这些列表写入 CSV 文件,以获取 0.5M 记录,将数据写入 CSV 文件需要不到 10 秒的时间。但问题是 StatefulBeanToCSV 将所有这些 0.5M 记录写入单个 CSV 文件,其大小变得更大..所以我需要一种方法将 CSV 文件限制为 20Mb。如果 CSV 文件的大小达到 20mb,我需要 StatefulBeanToCSV 写入新的 CSV 文件。非常感谢任何帮助。

public static void buildProductCsv(final List<Product> product,
                final String filePath) {

            try {

                Writer writer = new FileWriter(filePath);

                // mapping of columns with their positions
                ColumnPositionMappingStrategy<Product> mappingStrategy = new ColumnPositionMappingStrategy<Product>();
                // Set mappingStrategy type to Product Type
                mappingStrategy.setType(Product.class);
                // Fields in Product Bean
                String[] columns = new String[] { "productCode", "MFD", "EXD" };
                // Setting the colums for mappingStrategy
                mappingStrategy.setColumnMapping(columns);

                StatefulBeanToCsvBuilder<Product> builder = new StatefulBeanToCsvBuilder<Product>(writer);

                StatefulBeanToCsv<Product> beanWriter = builder.withMappingStrategy(mappingStrategy).build();
                // Writing data to csv file
                beanWriter.write(product);
                writer.close();

                log.info("Your csv file has been generated!");

            } catch (Exception ex) {
                log.warning("Exception: " + ex.getMessage());
            }

        }

最佳答案

这可能不是最好的方法,但您可以简单地检查一个 Product 对象的大小,然后您就会对可写入的最大子列表大小有一个抽象的想法一份 CSV。然后您可以迭代该列表,创建多个 CSV 文件。

要获取一种产品的尺寸,您可以使用以下方法。请注意,Product 对象应该是可序列化的。

  private static long getObjectSize( Object value ) // Pass product here
  {
    byte[] serializedObject;
    ByteArrayOutputStream byteArrayOutputStream = null;
    ObjectOutputStream objectOutputStream = null;

    try
    {
        byteArrayOutputStream = new ByteArrayOutputStream();
        objectOutputStream = new ObjectOutputStream( byteArrayOutputStream );
        objectOutputStream.writeObject( value );
        objectOutputStream.flush();
        serializedObject = byteArrayOutputStream.toByteArray();
        byteArrayOutputStream.flush();

        return Math.round( ( double ) serializedObject.length / ( 1024 * 1024 ) ); // Size in MB
    }
    catch( IOException e )
    {
        e.printStackTrace();
    }
    finally
    {
        try
        {
            if( byteArrayOutputStream != null )
            {
                byteArrayOutputStream.close();
            }
            if( objectOutputStream != null )
            {
                objectOutputStream.close();
            }
        }
        catch( IOException e )
        {
        }
    }
    return 0;
}

关于java - 使用 openCsv StatefulBeanToCSV 限制 CSV 文件大小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61284553/

相关文章:

csv - 使用 sed 查找并替换特定 csv 列中的多个模式

java - 如何从 Java 中的控制台应用程序获取实时输出

java - 如果服务器上的json数据发生变化,如何更新?

java - BufferedReader.ready() 行为的差异

spring-boot - 使用 Actuator 指标调整 Pod 大小 jvm.memory.max

iphone - 使用 CHCSVParser 的基础介绍

java - 在Java中,可以在下载前确定网页的大小吗?

java - 使用 spring boot 和 activiti 时找不到进程文件夹

java - 使用 QueryDSL 在两个不同字段中搜索值

linux - 显示.im6 : no decode delegate for this image format `/tmp/magick-KFcbfWUi'