EasyExcel读取多个Sheet页数据

使用EasyExcel一次性读取多个sheet页,通过EasyExcel.readSheet方法指定读取sheet页的下标,这里的sheet下标是从0开始的,可通过headRowNumber指定从哪一行开始读取,下标也是从0开始,如果表头是第一行,此时指定headRowNumber(0),此时会把表头也读取出来。默认是1。不同的sheet页在读取的时候可配置不同的监听器。

        String path = "D:\\Users\\lvhb\\Desktop\\test.xlsx";
        FileInputStream inputStream = new FileInputStream(path);

        ExcelReader excelReader = EasyExcel.read(inputStream).build();
        //一次性读取多个sheet页
        ReadSheet sheet3 = EasyExcel.readSheet(3).headRowNumber(1).registerReadListener(new ShipDataListener()).build();
        ReadSheet sheet4 = EasyExcel.readSheet(4).headRowNumber(1).registerReadListener(new ShipDataListener()).build();
        ReadSheet sheet5 = EasyExcel.readSheet(5).headRowNumber(1).registerReadListener(new ShipDataListener()).build();

        excelReader.read(sheet3,sheet4,sheet5);
        excelReader.finish();
  • 4
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
可以使用EasyExcel的工具类`ExcelReader`来读取多个sheet,并通过`SheetNameConverter`接口来获取sheet名称和数据对应关系。具体的步骤如下: 1. 创建一个`ExcelReader`对象,传入要读取Excel文件路径和读取数据的回调函数。 ``` ExcelReader excelReader = EasyExcel.read(filepath, new MyDataListener()).build(); ``` 2. 实现`SheetNameConverter`接口,并在`MyDataListener`中实例化该接口的对象,用于获取sheet名称和数据对应关系。 ``` public class MySheetNameConverter implements SheetNameConverter { private Map<String, String> sheetNameMap = new HashMap<>(); @Override public String convert(int sheetIndex, String sheetName) { sheetNameMap.put(sheetName, "Sheet" + sheetIndex); return sheetName; } public Map<String, String> getSheetNameMap() { return sheetNameMap; } } ``` 3. 在`MyDataListener`中重写`onSheet()`方法,将`SheetNameConverter`对象传入`Sheet`对象中,用于获取sheet名称和数据对应关系。 ``` public class MyDataListener extends AnalysisEventListener<Object> { private MySheetNameConverter sheetNameConverter; public MyDataListener() { sheetNameConverter = new MySheetNameConverter(); } @Override public void onSheet(int sheetNo, String sheetName) { super.onSheet(sheetNo, sheetName); Sheet sheet = EasyExcelFactory.readSheet(sheetNo).registerConverter(sheetNameConverter).build(); sheet.setSheetName(sheetName); sheet.setClazz(Object.class); EasyExcel.readSheet(sheet).headRowNumber(0).registerReadListener(this).doRead(); } // 其他方法省略 } ``` 4. 在读取完毕后,通过`MySheetNameConverter`的`getSheetNameMap()`方法获取sheet名称和数据对应关系。 ``` Map<String, String> sheetNameMap = sheetNameConverter.getSheetNameMap(); ```
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值