easyExcel 读取excel(按条读取)

MAVEN

xml 复制代码
      <!-- https://mvnrepository.com/artifact/com.alibaba/easyexcel -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>3.0.5</version>
        </dependency>

代码

java 复制代码
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
 
// 定义你的数据类,用于映射Excel中的字段
public class YourDataClass {
    // 定义字段,与Excel列名对应
    @ExcelProperty(index = 1)
    private String field1;
    @ExcelProperty(index = 2)
    private String field2;
    // getters and setters

    public String getField1() {
        return field1;
    }

    public void setField1(String field1) {
        this.field1 = field1;
    }

    public String getField2() {
        return field2;
    }

    public void setField2(String field2) {
        this.field2 = field2;
    }

    @Override
    public String toString() {
        return "YourDataClass{" +
                "field1='" + field1 + '\'' +
                ", field2='" + field2 + '\'' +
                '}';
    }
}

// 自定义监听器,用于处理读取到的数据
class YourDataListener extends AnalysisEventListener<YourDataClass> {
    @Override
    public void invoke(YourDataClass data, AnalysisContext context) {
        System.out.println(data);
        // 处理每条数据,例如保存到数据库或其他操作
    }
 
    @Override
    public void doAfterAllAnalysed(AnalysisContext context) {
        // 所有数据处理完毕后的操作
        System.out.println("doAfterAllAnalysed");
    }
}
 
// 读取Excel文件
class YourExcelReader {
    public void readExcel(String fileName) {
        // 读取第一个sheet
        EasyExcel.read(fileName, YourDataClass.class, new YourDataListener())
            .sheet()
            .doRead();
    }
}
 
// 使用
class Main {
    public static void main(String[] args) {
        YourExcelReader reader = new YourExcelReader();
        reader.readExcel("C:\\Users\\28698\\Documents\\xxxxx.xlsx");
    }
}

https://www.baidu.com/s?wd=easyexcel%E5%A4%8D%E6%9D%82%E6%95%B0%E6%8D%AE&rsv_spt=1&rsv_iqid=0xb82331eb0011cb00&issp=1&f=8&rsv_bp=1&rsv_idx=2&ie=utf-8&rqlang=cn&tn=57095150_7_oem_dg&rsv_enter=1&rsv_dl=tb&oq=easy&rsv_btype=t&inputT=4213&rsv_t=2e30yPMD2lAzHObglPAtRziTwFCyCpVyR2ekIw73AnkB02dVwyDmvPN1zFYStYSU1xWJM84rWg0&rsv_sug3=22&rsv_sug1=17&rsv_sug7=100&rsv_pq=b65dc51501a09efe&rsv_sug2=0&rsv_sug4=4513

相关推荐
virus59457 小时前
悟空CRM mybatis-3.5.3-mapper.dtd错误解决方案
java·开发语言·mybatis
初次见面我叫泰隆7 小时前
Qt——3、常用控件
开发语言·qt·客户端
没差c8 小时前
springboot集成flyway
java·spring boot·后端
无小道8 小时前
Qt——QWidget
开发语言·qt
时艰.8 小时前
Java 并发编程之 CAS 与 Atomic 原子操作类
java·开发语言
梵刹古音9 小时前
【C语言】 函数基础与定义
c语言·开发语言·算法
编程彩机9 小时前
互联网大厂Java面试:从Java SE到大数据场景的技术深度解析
java·大数据·spring boot·面试·spark·java se·互联网大厂
笨蛋不要掉眼泪9 小时前
Spring Boot集成LangChain4j:与大模型对话的极速入门
java·人工智能·后端·spring·langchain
梵刹古音9 小时前
【C语言】 结构化编程与选择结构
c语言·开发语言·嵌入式
Yvonne爱编码9 小时前
JAVA数据结构 DAY3-List接口
java·开发语言·windows·python