EasyExcel读取Excel数据、表头

本文介绍了如何在SpringBoot项目中使用EasyExcel库处理不同类型的Excel文件,包括单表头和多表头的读取方法,以及headRowNumber属性在设置表头行数时的作用。
摘要由CSDN通过智能技术生成

在使用easyExcel读取文件时,对于Excel的表头,在解析读取时分成不同的状态,需要加以区分.

1 环境准备

准备一个可以正常访问的SpringBoot项目.

1 添加pom

        <!-- https://mvnrepository.com/artifact/com.alibaba/easyexcel -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>3.0.5</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

2 添加dto对象

// 表格对应实体类
@Data
public class EasyExcelDemo {

    @ExcelProperty("标题")
    private String string;
    @ExcelProperty("日期")
    private Date date;
    @ExcelProperty("金额")
    private Double money;
    /**
     * 忽略这个字段
     */
    @ExcelIgnore
    private String name;
}
// 返回对象
@Data
public class Resp {
    private List<EasyExcelDemo> importList;

}

3 准备一个控制器

@RestController
@RequestMapping("/easyExcel")
@Slf4j
public class EasyExcelController {
    
    @PostMapping("/upload")
    public void upload(@RequestParam("file") MultipartFile file) throws IOException {
    	// 读取Excel    
        EasyExcel.read(file.getInputStream(), EasyExcelDemo.class,
                new EasyExcelListener()).sheet().headRowNumber(1).doRead();

        // 从监听中获取结果集
        Resp resp = EasyExcelListener.RESP.get();
        List<EasyExcelDemo> importList = resp.getImportList();
        log.info("导入集合 list = {}", importList);
        // 清除数据
        EasyExcelListener.RESP.remove();
    }
    
}

4 准备一个监听类

@Slf4j
public class EasyExcelListener extends AnalysisEventListener<EasyExcelDemo> {

    public static List<EasyExcelDemo> importList = new ArrayList<>();
    public static final ThreadLocal<Resp> RESP = new ThreadLocal<>();

    @Override
    public void invoke(EasyExcelDemo data, AnalysisContext context) {
        log.info("解析到的一条数据: excelRow = {}", data);
        importList.add(data);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext context) {
        // 解析完所有excel行, 保存到数据库或进行业务处理
        log.info("解析的所有数据 list = {}", importList);
        Resp resp = new Resp();
        resp.setImportList(importList);
        RESP.set(resp);
    }

    @Override
    public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
        log.info("表头数据 excelHead= {}", headMap);
    }
}

2 单表头Excel

单表头Excel, 即Excel的表头只有一行.

image-20220412223234618

如上单行表头, 在读取时,在EasyExcel读取时设置headRowNumber属性,表示Excel的表头的行数,默认为1,设置为1时,表示第一行是表头,从第二行是表数据

 EasyExcel.read(file.getInputStream(), EasyExcelDemo.class,
                new EasyExcelListener()).sheet().headRowNumber(1).doRead();

使用postman上传excel查看结果:

读取到Excel的表头

image-20220412223644136

读取到Excel的表数据

image-20220412223749574

3 多表头Excel

多表头Excel, 即Excel的表头有多行.

image-20220412224038861

如上单行表头, 在读取时,在EasyExcel读取时设置headRowNumber属性,表示Excel的表头的行数,设置为2时,表示第二和之前行都是表头.

 EasyExcel.read(file.getInputStream(), EasyExcelDemo.class,
                new EasyExcelListener()).sheet().headRowNumber(2).doRead();

使用postman上传excel查看结果:

读取到Excel的表头, 读取到第一行

image-20220412224243726

接着读取表头第二行

image-20220412224310581

读取到Excel的表数据

image-20220412224401107

4 总结

关于EasyExcel的表格读取,使用起来比较方便,但是对于多表头和单表头的读取,需要注意,是按照一层层的解析的.即再一些特殊的场景,需要校验表格的表头是否正确等, 要注意多表头的读取按照行数顺序读取数据.

读取Excel文档并返回映射后的Java对象这一操作封装成公共方法可以提高代码的复用性。以下是一个简单的示例,可以帮助你了解如何使用EasyExcel封装读取Excel的公共方法: ```java public class ExcelUtil { /** * 读取Excel数据并将其映射成Java对象 * * @param inputStream 输入流 * @param clazz 映射的Java类 * @param sheetNo Sheet页码(从0开始) * @param headRowNum Excel表头行号(从0开始) * @return 映射后的Java对象列表 */ public static <T> List<T> readExcel(InputStream inputStream, Class<T> clazz, int sheetNo, int headRowNum) throws IOException { ExcelReader reader = EasyExcelFactory.read(inputStream).build(); ReadSheet readSheet = EasyExcelUtil.getReadSheet(clazz, sheetNo, headRowNum); List<T> dataList = reader.read(readSheet); reader.finish(); return dataList; } /** * 获取读取数据的Sheet对象 * * @param clazz 映射的Java类 * @param sheetNo Sheet页码(从0开始) * @param headRowNum Excel表头行号(从0开始) * @return ReadSheet对象 */ public static <T> ReadSheet getReadSheet(Class<T> clazz, int sheetNo, int headRowNum) { Sheet sheet = new Sheet(sheetNo, headRowNum, clazz); sheet.useUnmergedCells(true); sheet.setAutoWidth(true); return EasyExcelUtil.getReadSheet(sheet); } } ``` 在以上示例中,我们首先定义了一个`ExcelUtil`类,并在其中封装了两个公共方法: - `readExcel`方法:用于读取Excel数据并将其映射成Java对象。 - `getReadSheet`方法:用于获取读取数据的Sheet对象。 使用这两个公共方法,我们可以很方便地读取Excel数据并将其映射成Java对象。例如: ```java public class ReadExcelDemo { public static void main(String[] args) throws IOException { // 创建输入流,读取Excel文件 InputStream inputStream = new FileInputStream("test.xlsx"); // 读取Excel数据 List<User> userList = ExcelUtil.readExcel(inputStream, User.class, 0, 0); // 遍历读取到的数据 for (User user : userList) { System.out.println(user); } // 关闭流 inputStream.close(); } } ``` 在以上示例中,我们首先创建了一个输入流,用于读取Excel文件。然后,我们调用`ExcelUtil.readExcel`方法读取Excel数据,并将其映射成`User`对象。最后,我们遍历读取到的数据,并在控制台输出每一行数据的内容。需要注意的是,我们需要确保关闭流,以防止资源泄漏。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值