easypoi使用笔记(apache)

本文介绍如何在pom.xml中添加EasyPoi依赖,用于Spring Boot项目。EasyPoi是一个强大的Excel读写工具,能高效处理大量数据,支持复杂表格样式。通过示例演示项目,可快速上手并进行测试。


easypoi是apache的产品。
设计的初衷就是简化操作(对比poi)。
所以,easypoi的核心设计初衷:
易用,高性能,内存使用率低(或内存利用率高)。

导入多sheet

场景:
一个excel有多个sheet,如何分别处理呢。

有两种方案:
1、逐个sheet解析,不过我们找到方法。
2、直接使用ExcelImportUtil(这种应该可以直接复用注解)。

ByteArrayOutputStream cacheInputStream = new ByteArrayOutputStream();
IoUtil.write(cacheInputStream, true, IoUtil.readBytes(file.getInputStream()));

Workbook workbook = WorkbookFactory.create(file.getInputStream());
int numberOfSheets = workbook.getNumberOfSheets();
ImportParams params = new ImportParams();
params.setHeadRows(1); // 设置标题行数
params.setSheetNum(1); // 这个是读取几个sheet 永远为1
for (int i = 0; i <numberOfSheets ; i++) {
    params.setStartSheetIndex(i);
    InputStream inputStreamSingleton=null;
    if(0==i){ // user
        inputStreamSingleton = new ByteArrayInputStream(cacheInputStream.toByteArray());
        fpExcelImportResult = ExcelImportUtil.importExcelMore(inputStreamSingleton, User.class, params);
    }else if(1==i){ org
        inputStreamSingleton = new ByteArrayInputStream(cacheInputStream.toByteArray());
        jtkpExcelImportResult = ExcelImportUtil.importExcelMore(inputStreamSingleton, Org.class, params);
    }else if(2==i){

    }
}

注:ImportParams 设置读取第几页:


params.setStartSheetIndex(i); // 从哪个sheet开始 应该用这个
params.setSheetNum(i); // 这个是往后读取几个sheet,这里始终设置为1即可

也就是相当于i根据for循环来走,sheetNum始终设置为1,始终读一页,就实现了循环读取每个sheet

开始弄错了,params.setSheetNum(i),这样显然不对,例如总共6个sheet,到第4个sheet了,再往后读取6个,肯定没有sheet啊,所以报错了。

springboot集成easypoi

pom.xml中添加依赖

<dependency>
	<groupId>cn.afterturn</groupId>
	<artifactId>easypoi-spring-boot-starter</artifactId>
	<version>4.2.0</version>
</dependency>

其他

gitee easypoi 地址(这个算是官网):
https://gitee.com/lemur/easypoi

gitee easypoi演示项目,可以用来测试
https://gitee.com/lemur/easypoi-test

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值