java大excel文件_POI-处理大Excel文件(xlsx)

上次简述了使用poi读取大xls文件,这里说下读取xlsx格式的文件的方法

环境模拟

先准备一个大的excel文件(xlsx大小5M),再将jvm的heap缩小到100m(JVM 参数 -Xmx100m)用于模拟OOM

并使用参数在OOM时dump内存 -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=d://dump.hprof

使用XSSF读取

在gradle中引入解析xlsx需要的jar包

compile 'org.apache.poi:poi:3.15'

compile 'org.apache.poi:poi-ooxml:3.15'

compile 'xerces:xercesImpl:2.11.0'

之后读取xlsx文件

public static void main(String [] args) throws IOException {

InputStream is = new FileInputStream("d://large.xlsx");

Workbook wb = new XSSFWorkbook(is);

}

运行之后

Exception in thread "main" java.lang.OutOfMemoryError: Java heap space

at java.util.Arrays.copyOf(Arrays.java:3236)

at java.io.ByteArrayOutputStream.toByteArray(ByteArrayOutputStream.java:178)

at org.apache.poi.openxml4j.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值