EasyExcel读取excel内容
实体类
package com.atguigu.yygh.cmn.controller; import com.alibaba.excel.annotation.ExcelProperty; import lombok.Data; import java.io.Serializable; @Data public class User implements Serializable { private static final long serialVersionUID = -6809015731102988151L; @ExcelProperty(index = 0) private String name; @ExcelProperty(index = 1) private Integer age; }
监听器
package com.atguigu.yygh.cmn.listener; import com.alibaba.excel.context.AnalysisContext; import com.alibaba.excel.event.AnalysisEventListener; import java.util.ArrayList; import java.util.List; public class UserLisener<T> extends AnalysisEventListener<T> { /** * 自定义用于暂时存储data * 可以通过实例获取该值 */ private List<T> datas = new ArrayList<>(); /** * 每解析一行都会回调invoke()方法 * * @param object 读取后的数据对象 * @param context 内容 */ @Override public void invoke(Object object, AnalysisContext context) { T map = (T) object; //数据存储到list,供批量处理,或后续自己业务逻辑处理。 datas.add(map); } @Override public void doAfterAllAnalysed(AnalysisContext analysisContext) { //解析结束销毁不用的资源 //注意不要调用datas.clear(),否则getDatas为null } /** * 返回数据 * * @return 返回读取的数据集合 **/ public List<T> getDatas() { return datas; } /** * 设置读取的数据集合 * * @param datas 设置读取的数据集合 **/ public void setDatas(List<T> datas) { this.datas = datas; } }
测试代码
@GetMapping("readExcel")
public void readExcel(String filePath){
String file = filePath + "data.xlsx";
UserLisener<User> userUserLisener = new UserLisener<>();
EasyExcel.read(file, User.class,userUserLisener).sheet("Sheet1").doRead();
List<User> datas = userUserLisener.getDatas();
System.out.println(datas);
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律