实体类
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); }
标签:读取,List,EasyExcel,excel,import,com,public,datas From: https://www.cnblogs.com/ixtao/p/17396468.html