阿里EasyExcel使用
报错一:使用EasyExcel解析表格时报错ExcelAnalysisException: File type error,io must be available markSupported
https://blog.csdn.net/qq_42910468/article/details/103574522
1 | InputStream inputStream = new BufferedInputStream( new FileInputStream(fileUrl)); |
开发
<!-- 阿里开源EXCEL --> <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.1.6</version> </dependency>
package com.power.manager; import com.alibaba.excel.EasyExcel; import com.alibaba.excel.context.AnalysisContext; import com.alibaba.excel.event.AnalysisEventListener; import com.power.manager.dto.WeekPowerLineLossExcelDto; import org.junit.Test; import java.io.BufferedInputStream; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.InputStream; import java.util.ArrayList; import java.util.List; public class EasyExcelTest { @Test public void importExcel() throws FileNotFoundException { String url = "E:\\test\\test\\202002\\2002xiansun.xls"; InputStream is = new BufferedInputStream(new FileInputStream(url)); final int CAPACITY = 5000; List<WeekPowerLineLossExcelDto> list = new ArrayList<>(CAPACITY); System.out.println("开始"); EasyExcel.read(is, WeekPowerLineLossExcelDto.class, new AnalysisEventListener<WeekPowerLineLossExcelDto>() { @Override public void invoke(WeekPowerLineLossExcelDto dto, AnalysisContext analysisContext) { list.add(dto); if(list.size() >= CAPACITY){ System.out.println(list.size()); list.clear(); } } @Override public void doAfterAllAnalysed(AnalysisContext analysisContext) { System.out.println("最终剩余:" + list.size()); list.clear();//解析结束销毁不用的资源 } }).sheet().doRead(); System.out.println("结束"); } }
package com.power.manager.dto; import com.alibaba.excel.annotation.ExcelProperty; import lombok.Data; /** * 参考:https://juejin.im/post/5dae4fdd51882554c07585d1 * 导入 */ @Data public class WeekPowerLineLossExcelDto { //序号 @ExcelProperty(index = 0) private Integer num; @ExcelProperty(index = 1) private String countDate; @ExcelProperty(index = 2) private String powerSupplyCompanyName; }
运行结果:
开始
5000
5000
5000
最终剩余:1308
结束
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
2019-03-10 Maven的<profile>标签的使用