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

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
     */
    @Override
    public void invoke(UserInfo data, AnalysisContext context) {
        System.out.println(data);
    }

    /**
     * 所有数据解析完成了 都会来调用
     *
     * @param context
     */
    @Override
    public 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 同步读取会自动finish
        List<UserInfo> TotalDataList = EasyExcel.read(fileName).head(UserInfo.class).sheet().doReadSync();
        for (UserInfo data : TotalDataList) {
            System.out.println(data);
        }
    }

特点:

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

运行结果

在这里插入图片描述


http://www.kler.cn/a/316455.html

相关文章:

  • python实战(八)——情感识别(多分类)
  • ORA-01092 ORA-14695 ORA-38301
  • 记录日志中logback和log4j2不能共存的问题
  • 论文阅读《机器人状态估计中的李群》
  • macOS 设置固定IP
  • JMeter基础篇
  • [C#]winform 使用opencvsharp实现玉米粒计数
  • 基于windows的mysql5.7安装配置教程
  • Vue 实现高级穿梭框 Transfer 封装
  • Qt 模型视图(四):代理类QAbstractItemDelegate
  • 【数字组合】
  • C基础语法2
  • 提升动态数据查询效率:应对数据库成为性能瓶颈的优化方案
  • 【C语言零基础入门篇 - 16】:栈和队列
  • 新一代图像生成E2E FT:深度图微调突破
  • iOS界面布局:屏幕尺寸与安全区域全面指南
  • 什么是unix中的fork函数?
  • 【RabbitMQ】快速上手
  • Spring Boot 2.x基础教程:实现文件上传
  • [Unity Demo]从零开始制作空洞骑士Hollow Knight第五集:再制作更多的敌人
  • 【艾思科蓝】前端框架巅峰对决:React、Vue与Angular的全面解析与实战指南
  • 经典sql题(七)查找直播间最大在线人数
  • HDL coder使用手册
  • 【产品思考】低代码理解与国内落地
  • 【python】数据爬虫,抓取并分析豆瓣电影信息
  • 1网络安全的基本概念