gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 00:56:36 25 4
gpt4 key购买 nike

我有一个对象列表,比如说我从数据库获得的产品列表。我能够使用 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com