Easy操作Excel导入

Controller

public GbmResult batchReadFile(@RequestParam(required = false,name ="file") MultipartFile file) throws IOException {
    String fileName = file.getOriginalFilename();
    String suffixName = fileName.substring(fileName.lastIndexOf("."));
    if (!(suffixName.equals(".xlsx"))) {
      System.out.println("请上传xlsx格式文件");
    }
    Listener listener = new Listener (TestService);    EasyExcel.read(file.getInputStream(),MgbsupplierBatchDto.class,listener).sheet().doRead();
    return Listener .getResult();
}

MgbsupplierBatchDto.class 导入Excel的类

监视器

@Slf4j
public class Listener extends AnalysisEventListener<TestDto> {
    List<TestDto> list = new ArrayList<TestDto>();
   //这是需要做业务的service
    private TestService testService;
    private Map<String,Object> map = new HashMap<String,Object>(){
        {
            put("success",0);
            put("message","");           
        }
    };
    public Map<String,Object> getResult(){
        return this.map;
    }
    public Listener(TestService testService){
        this.testService= testService;
    }
    @Override
    public void invoke(MgbsupplierBatchDto mgbsupplierBatchDto, AnalysisContext analysisContext) {
             //有什么判断都可以在这里做
            list.add(mgbsupplierBatchDto); 
    }
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
     //读取完excel,最后执行这里
    this.map=testService.readBatch(list,map);
    }
}

//过来excel的空行

private static boolean isAllNull(MgbsupplierBatchDto t) {
    for (Method method : methods) {
        if (method.getName().contains("get") && method.getParameterCount() == 0) {
            if(!StringUtils.contains(method.getName(),"getCellStyleMap")&&!StringUtils.contains(method.getName(),"getClass") ){
                Object invoke = null;
                try {
                    invoke = method.invoke(t);
                } catch (IllegalAccessException e) {
                    log.error(e.toString(),e);
                } catch (InvocationTargetException e) {
                    log.error(e.toString(),e);
                }
                if (ToolUtil.isNotEmpty(invoke)) {
                    return false;
                }
            }

        }
    }
    return true;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值