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

1406

被折叠的 条评论
为什么被折叠?



