您的位置:首页 > 游戏 > 手游 > 家具设计师培训班_开发一个商城网站多少钱_2023新闻摘抄大全_五合一网站建设

家具设计师培训班_开发一个商城网站多少钱_2023新闻摘抄大全_五合一网站建设

2024/12/22 14:22:06 来源:https://blog.csdn.net/m0_73731267/article/details/142303404  浏览:    关键词:家具设计师培训班_开发一个商城网站多少钱_2023新闻摘抄大全_五合一网站建设
家具设计师培训班_开发一个商城网站多少钱_2023新闻摘抄大全_五合一网站建设

使用EasyExcel导入Excel数据有两种方式
无论哪种方式我们都需要建立Excel表格和Java对象的绑定
首先我们需要根据Excel表头定义一个对应的类

excel表示例:

在这里插入图片描述

对应的类:

使用@ExcelProperty将excel列名和字段名绑定,括号里面填列名

package com.hjm.yupao.once;import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;import java.util.Date;/*** 用户信息*/
@Data
public class UserInfo {/*** 星球编号*/@ExcelProperty("成员编号")private String planetCode;/*** 用户昵称*/@ExcelProperty("成员昵称")private String username;@ExcelProperty("成员积分")private Double score;
}

第一种:监听器

先创建一个监听器,在读取数据时绑定监听器

监听器

package com.hjm.yupao.once;import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.read.listener.ReadListener;
import lombok.extern.slf4j.Slf4j;// 有个很重要的点 UserInfoListener 不能被spring管理,要每次读取excel都要new,然后里面用到spring可以构造方法传进去
@Slf4j
public class TableListener implements ReadListener<UserInfo> {/*** 这个每一条数据解析都会来调用** @param data    one row value. Is is same as {@link AnalysisContext#readRowHolder()}* @param context*/@Overridepublic void invoke(UserInfo data, AnalysisContext context) {System.out.println(data);}/*** 所有数据解析完成了 都会来调用** @param context*/@Overridepublic void doAfterAllAnalysed(AnalysisContext context) {// 这里也要保存数据,确保最后遗留的数据也存储到数据库System.out.println("已解析完成");}
}
 /*** 第一种方式:使用监听器* @param fileName*/private static void readByListener(String fileName) {// 这里默认每次会读取100条数据 然后返回过来 直接调用使用数据就行// 具体需要返回多少行可以在`PageReadListener`的构造函数设置EasyExcel.read(fileName, UserInfo.class, new TableListener()).sheet().doRead();}

特点

  • 单独抽离处理逻辑,代码清晰易于维护
  • 一条一条处理,适用于数据量大的场景

第二种:同步的返回

 /*** 第二种方式:同步的返回,不推荐使用,如果数据量大会把数据放到内存里面* @param fileName*/public static void synchronousRead(String fileName) {// 这里 需要指定读用哪个class去读,然后读取第一个sheet 同步读取会自动finishList<UserInfo> TotalDataList = EasyExcel.read(fileName).head(UserInfo.class).sheet().doReadSync();for (UserInfo data : TotalDataList) {System.out.println(data);}}

特点:

  • 无需创建监听器,一次性获取完整数据
  • 方便简单,但是数据量大时会有等待时长,也可能内存溢出

运行结果

在这里插入图片描述

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com