当前位置: 首页 > news >正文

EasyExcel的基本使用——Java导入Excel数据

使用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);}}

特点:

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

运行结果

在这里插入图片描述

http://www.lryc.cn/news/441927.html

相关文章:

  • Apache Iceberg 试用
  • 速通汇编(六)认识栈,SS、SP寄存器,push和pop指令的作用
  • 【Python机器学习】NLP信息提取——值得提取的信息
  • 代理IP批理检测工具,支持socks5,socks4,http和https代理批量检测是否可用
  • AI视觉算法盒是什么?如何智能化升级网络摄像机,守护全方位安全
  • 【Vue】VueRouter路由
  • idea多模块启动
  • 23:SPI二:W25Q64存储器模块的使用
  • 论文解读《COMMA: Co-articulated Multi-Modal Learning》
  • 10款电脑加密软件超好用推荐|2024年常用电脑加密软件排行榜
  • 用户态缓存:环形缓冲区(Ring Buffer)
  • Harmony应用 ArkTs AES 加密方法之GCM对称加密
  • 热成像在战场上的具体作用!!!
  • 2024年09月20日《每日一练》
  • 使用 SSCB 保护现代高压直流系统的优势
  • Linux基础命令——文件系统的日常管理
  • uniapp使用高德地图设置marker标记点,后续根据接口数据改变某个marker标记点,动态更新
  • 坦白了,因为这个我直接爱上了 FreeBuds 6i
  • 006.MySQL_查询数据
  • 【C#生态园】从图像到视觉:Emgu.CV、AForge.NET、OpenCvSharp 全面解析
  • 1、无线通信的发展概况
  • 虚拟机安装xubuntu
  • 携手鲲鹏,长亮科技加速银行核心系统升级
  • 新鲜的Win11/10镜像,全系列下载!
  • iPhone 16系列:摄影艺术的全新演绎,探索影像新境界
  • 移动应用开发中的技术选择:优缺点全面解析
  • 宿舍管理系统的设计与实现 (含源码+sql+视频导入教程)
  • 原生+jquery写自动消失的提示框
  • Android14 蓝牙 BluetoothService 启动和相关代码介绍
  • 【秋招笔试-支持在线评测】9.19小米秋招(已改编)-三语言题解