关于EasyExcel的invoke方法读取多少列

首先在easyexcel监听器里面定义一个dataList用于得到invoke按行读取的数据的数据

private final List<Map<Integer, String>> dataList;

public void invoke(Map<Integer, String> data, AnalysisContext context) {
        dataList.add(data);
}

public List<Map<Integer, String>> getDataList(){
       return dataList;
}

在新建一个test.xlsx内容如下:

测试一下 

public class Test {
    public static void main(String[] args) {
        ExcelListener excelListener=new ExcelListener();
        EasyExcel.read("C:\\Users\\dell\\Desktop\\test.xlsx", excelListener)
                .sheet(0)
                .doRead();
        for (Map<Integer, String> map : excelListener.getDataList()) {
            System.out.println(map.size());
        }
    }
}

打印结果得到

 得出结论:EasyExcel的invoke方法得到的map<Integer,String>是默认按表头的长度来计算的,超出表头的列也可以读到,比表头短的列则为null添加到map中。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值