GitHub Star 8800+ 的阿里开源的 Java 解析 Excel 工具

【公众号回复 “1024”,免费领取程序员赚钱实操经验】

640?wx_fmt=png

我们在项目中经常会遇到操作 Excel 的需求,比如导入、导出 Excel 报表,Java 操作 Excel 基本上都用 POI,但 POI 操作起来比较麻烦,需要创建很多 row,cell 以及样式,而且非常耗内存。

为了简便这种操作,Alibaba 开源了 easyexcel,easyexcel 重写了 POI 对 07 版 Excel 的解析,能够把原本一个 3M 的 Excel 用 POI sax 依然需要 100M 左右内存降低到几 M,并且再大的 Excel 不会出现内存溢出,03 版依赖 POI 的 sax 模式。

该项目实现了列表数据的导入,分页列表导出,支持自定义格式,支持模版以及模板和列表的混合导出。在上层做了模型转换的封装,是一个快速、简单避免 OOM 的 Java 处理 Excel 工具。

easyexcel 核心原理:

1、文件解压文件读取通过文件形式

640?wx_fmt=png

2、避免将全部数据一次加载到内存

采用 sax 模式一行一行解析,并将一行的解析结果以观察者模式通知处理。

640?wx_fmt=png

3、抛弃不重要的数据

Excel 解析时候会包含样式、字体、宽度等数据,但这些数据是可以不关心的,如果将这部分数据抛弃可以大大降低内存使用。

开源项目地址:https://github.com/alibaba/easyexcel

开源项目组织:Alibaba

推荐阅读:

你用的字体经过授权了么?

相关破解技术仅限于研究使用,不准用于非法目的,否则后果自负

一个比今日头条有价值的今日热榜


今天的推荐不知道大家喜欢吗?如果你喜欢,请在文章底部留言和点赞,以表示对我的支持,你们的留言、点赞和转发关注是我持续更新的动力哦!

「GitHub精选」开始接受大家投稿啦

「GitHub精选」,每晚10:24准时为您推送

640?wx_fmt=png

  • 9
    点赞
  • 56
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值