两种读取对象的方式
1.确定表头:建立对应的对象实体类 进行映射
2.不确定的表头:每一行数据映射为Map<String,Object>
两种读取模式
1.监听器:先创建监听器对象 在读取文件时绑定监听器 单独抽取处理逻辑 代码清晰维护 一条条处理 适用于大数据量的场景
@Slf4j
public class TableListener implements ReadListener<TableUserInfo> {
/**
* 这个每一条数据解析都会来调用
*
* @param data one row value. Is is same as {@link AnalysisContext#readRowHolder()}
* @param context
*/
@Override
public void invoke(TableUserInfo data, AnalysisContext context) {
System.out.println(data);
}
/**
* 所有数据解析完成了 都会来调用
*
* @param context
*/
@Override
public void doAfterAllAnalysed(AnalysisContext context) {
System.out.println("已解析完成");
}
}
2.同步器:无需创建监听器 要获取完整数据 一次性读取所有数据
public class ImportExcel {
public static void main(String[] args) {
String fileName = "D:\\桌面\\用户中心项目\\code\\user-center\\src\\main\\resources\\table_user_info.xlsx";
readByListener(fileName);
synchronousRead(fileName);
}
//监听器模式
private static void readByListener(String fileName){
// 写法1:JDK8+ ,不用额外写一个DemoDataListener
// since: 3.0.0-beta1
// 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
// 这里每次会读取3000条数据 然后返回过来 直接调用使用数据就行
EasyExcel.read(fileName, TableUserInfo.class,new TableListener()).sheet().doRead();
}
//同步器模式
private static void synchronousRead(String fileName){
// 这里 需要指定读用哪个class去读,然后读取第一个sheet 同步读取会自动finish
List<TableUserInfo> totalDataList = EasyExcel.read(fileName).head(TableUserInfo.class).sheet().doReadSync();
for (TableUserInfo tableUserInfo : totalDataList) {
System.out.println(tableUserInfo);
}
}
}