跳到主要内容

简单读取

本章节介绍如何使用 FastExcel 完成简单 Excel 读取

数据监听器

概述

FastExcel 提供监听器机制,用于在读取 Excel 文件时对每一行数据进行处理。

使用

数据监听器需要实例化并支持多种不同的使用方式。

实例化

监听器不能被 Spring 管理,每次读取 Excel 文件时需要重新实例化。

Lambda表达式

@Test
public void simpleRead() {
String fileName = "path/to/demo.xlsx";

FastExcel.read(fileName, DemoData.class, new PageReadListener<>(dataList -> {
for (DemoData demoData : dataList) {
log.info("读取到一条数据: {}", JSON.toJSONString(demoData));
}
})).sheet().doRead();
}

匿名内部类

@Test
public void simpleRead() {
String fileName = "path/to/demo.xlsx";

FastExcel.read(fileName, DemoData.class, new ReadListener<DemoData>() {
@Override
public void invoke(DemoData data, AnalysisContext context) {
log.info("读取到一条数据: {}", JSON.toJSONString(data));
}

@Override
public void doAfterAllAnalysed(AnalysisContext context) {
log.info("所有数据读取完成!");
}
}).sheet().doRead();
}

数据监听器

@Test
public void simpleRead() {
String fileName = "path/to/demo.xlsx";

FastExcel.read(fileName, DemoData.class, new DemoDataListener())
.sheet()
.doRead();
}

POJO 类与监听器

概述

FastExcel 提供了一种简单的方式来读取 Excel 文件。用户只需定义一个 POJO 类来表示数据结构,然后通过 FastExcel 的监听器机制读取数据。

POJO 类

与 Excel 结构对应的 POJO 类 DemoData

@Getter
@Setter
@EqualsAndHashCode
public class DemoData {
private String string;
private Date date;
private Double doubleData;
}

数据监听器

DemoDataListener 是一个自定义监听器,用于处理从 Excel 中读取的数据。

@Slf4j
public class DemoDataListener implements ReadListener<DemoData> {

@Override
public void invoke(DemoData data, AnalysisContext context) {
log.info("读取到一条数据: {}", JSON.toJSONString(data));
}

@Override
public void doAfterAllAnalysed(AnalysisContext context) {
log.info("所有数据读取完成!");
}
}

代码示例

@Test
public void simpleRead() {
String fileName = "path/to/demo.xlsx";

FastExcel.read(fileName, DemoData.class, new DemoDataListener())
.sheet()
.doRead();
}

无 POJO 类与监听器

概述

FastExcel 支持不定义 POJO 类直接读取 Excel 文件,通过 Map<Integer, String> 直接读取数据,其中的键为列索引,值为单元格数据

数据监听器

@Slf4j
public class NoModelDataListener extends AnalysisEventListener<Map<Integer, String>> {

@Override
public void invoke(Map<Integer, String> data, AnalysisContext context) {
log.info("读取到一条数据: {}", JSON.toJSONString(data));
}

@Override
public void doAfterAllAnalysed(AnalysisContext context) {
log.info("所有数据读取完成!");
}
}

同步读取

概述

使用 doReadSync 方法直接将 Excel 数据读取为内存中的列表,这种方法推荐用于数据量较小的场景。读取的数据可以是 POJO 对象列表或 Map 列表。

POJO 类

与 Excel 结构对应的 POJO 类 DemoData

@Getter
@Setter
@EqualsAndHashCode
public class DemoData {
private String string;
private Date date;
private Double doubleData;
}

代码示例

读取为 POJO 对象列表

@Test
public void synchronousReadToObjectList() {
String fileName = "path/to/demo.xlsx";

// POJO 列表
List<DemoData> list = FastExcel.read(fileName)
.head(DemoData.class)
.sheet()
.doReadSync();

for (DemoData data : list) {
log.info("读取到的数据: {}", JSON.toJSONString(data));
}
}

读取为 Map 列表

在不使用 POJO 情况下,可以将每一行读取为 Map,键为列索引,值为单元格内容。

@Test
public void synchronousReadToMapList() {
String fileName = "path/to/demo.xlsx";

// Map 列表
List<Map<Integer, String>> list = FastExcel.read(fileName)
.sheet()
.doReadSync();

for (Map<Integer, String> data : list) {
log.info("读取到的数据: {}", JSON.toJSONString(data));
}
}