通过混合方式处理需要在固定模板中大批量写入数据的excel的方法

业务需要在一个既存固定样式(列头,背景,固定列,过滤等等)的excel里面写入大量数据。

 

  已知XSSFWorkBook在大量写入数据时会有严重的性能问题,并导致内存泄漏,而SXSSFWorkBook适合写入大量数据,但不适合操作模板。

 

   直接介绍解决办法

通过XSSFWorkBook读入带有样式的模板

XSSFWorkbook wb = (XSSFWorkbook)WorkbookFactory.create(fis);

通过wb创建SXSSFWorkBook对象用作大量数据操作

SXSSFWorkbook sxw = new SXSSFWorkbook(wb,100);

关键点:

如果需要操作模板,比如读写或填充单元格、行,需要通过XSSFSheet对象

如删除某行

XSSFSheet orgSheet = wb.getSheetAt(0);
Row templateTypeRow = orgSheet.getRow(0);
orgSheet.removeRow(templateTypeRow);

如果要大批量写入数据,需要通过SXSSFSheet

SXSSFSheet templateSheet = sxw.getSheetAt(0);
for(int i=0;i<数据.length;i++
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值