微笑精灵 2022-10-14 10:28 采纳率: 93.8%
浏览 89
已结题

EasyExcel读取表格怎么做泛型?

现在有一个表格解析,用的是EasyExce,现在表格可能有两种,两种表格表头不一致,也就是会得到不同的类,但是因为是同一个业务,所以我想把它们做成一个抽象类里面然后写不同的实现,但是现在遇见一个问题,EasyExcel的读取需要传入一个class作为读取出的参数类型,但是现在这么写可以编译,但是会发生类型转换异常,asbdto是我的两个需要映射出来的类的父类,但是它不能转成DTO的运行时我输入的类型。
请问有什么办法么?DTO是泛型标识,在实现类或者运行时它是AbsDto的子类


 protected List<DTO> parse(InputStream in){
        List<DTO> list=new CopyOnWriteArrayList<>();
        EasyExcel.read(in,AbsDto.class ,new AnalysisEventListener<DTO>() {
            // 每读取一行数据, 该方法会被调用一次
            @Override
            public void invoke(DTO testExcel, AnalysisContext analysisContext) {
                list.add(testExcel);
            }

            // 全部读取完成被调用
            @Override
            public void doAfterAllAnalysed(AnalysisContext analysisContext) {
               log.debug("表格读取完成");
            }
        }).sheet(0).headRowNumber(0).doRead();
  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2022-10-14 11:12
    关注
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月29日
  • 已采纳回答 10月21日
  • 创建了问题 10月14日

悬赏问题

  • ¥15 yolov8边框坐标
  • ¥15 matlab中使用gurobi时报错
  • ¥15 WPF 大屏看板表格背景图片设置
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真