栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Apache POI流式传输(SXSSF)用于阅读

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Apache POI流式传输(SXSSF)用于阅读

在深入研究之后,我发现了这个库:

如果您过去使用过Apache
POI来读取Excel文件,您可能会注意到它的内存效率不是很高。阅读整个工作簿将导致严重的内存使用高峰,这可能会对服务器造成严重破坏。

为什么要在整个工作簿中读取Apache,有很多充分的理由,但是大多数原因与该库允许您使用随机地址进行读取和写入有关。如果(并且仅)您只想以快速且高效的内存方式读取Excel文件的内容,则可能不需要此功能。不幸的是,POI库中唯一可读取流工作簿的内容要求您的代码使用类似SAX的解析器。该API缺少所有友好类(如Row和Cell)。

该库用作该流API的包装,同时保留了标准POI API的语法。继续阅读以了解它是否适​​合您。

InputStream is = new FileInputStream(new File("/path/to/workbook.xlsx"));StreamingReader reader = StreamingReader.builder()        .rowCacheSize(100)    // number of rows to keep in memory (defaults to 10)        .bufferSize(4096)     // buffer size to use when reading InputStream to file (defaults to 1024)        .sheetIndex(0)        // index of sheet to use (defaults to 0)        .sheetName("sheet1")  // name of sheet to use (overrides sheetIndex)        .read(is); // InputStream or File for XLSX file (required)

还有一个SAX Event API,它通过事件读取文档并解析其内容。

如果内存占用量是一个问题,那么对于XSSF,您可以获取基础XML数据并自行处理。这是为那些愿意学习.xlsx文件的低级结构并且乐于使用Java处理XML的中级开发人员准备的。它使用起来相对简单,但是需要对文件结构有基本的了解。所提供的优点是您可以读取内存占用相对较小的XLSX文件。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/427943.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号