【springboot】【easyexcel】excel文件读取

pom.xml

<dependency>
   <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>3.1.1</version>
</dependency>

ExcelVo

字段映射

@Data
public class ExcelVo {
   
    @ExcelProperty(value = "序号", index = 0)
    private Integer num;
    @ExcelProperty(value = "工号", index = 1)
    private String id;
    @ExcelProperty(value = "姓名", index = 2)
    private String username;
    ...
}

逐行读取并处理

controller:接收文件接口

@RequestMapping(value = "/upload", method = RequestMethod.POST)
public JsonResult upload(@RequestParam("file") MultipartFile file) {
   
     if (file.isEmpty()) {
   
         return false;
     }
     try {
   
         ExcelListener excelListener = new ExcelListener();
         EasyExcel.read(file.getInputStream(), ExcelVo.class, excelListener).sheet().doRead();
         return true;
     }catch (Exception e){
   
     }
 }

ExcelListener :逐行处理

@Component
public class ExcelListener extends AnalysisEventListener<ExcelVo> {
   
    public static ExcelListener excelListener; //声明对象
    @PostConstruct //初始化
    public void init() {
   
        excelListener = this;
        excelListener.resultService = this.resultService;
    }
    @Autowired
    private ResultService resultService;
    
    @Override
    public void invoke(ExcelVo excelVo, AnalysisContext analysisContext) {
   
        excelListener.resultService.updateLevel(excelVo);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
   
        System.out.println("excel读取完成");
    }
}

全部读取并处理

controller:接收文件接口

@RequestMapping(value = "/upload", method = RequestMethod.POST)
    public JsonResult upload(@RequestParam("file") MultipartFile file, @RequestParam("city") String city, @RequestParam("username") String username) {
   
        if (file.isEmpty()) {
   
            throw new RuntimeException("文件上传失败");
        }
        try {
   
            ExcelListener excelListener = new ExcelListener();
            EasyExcel.read(file.getInputStream(), ExcelVo.class, excelListener).sheet().doRead();
            List<ExcelVo> list = excelListener.getList();
            namelistService.insertList(list, city, username);
            return JsonResult.ok(true);
        } catch (Exception e) {
   
        }
    }

ExcelListener :逐行存入list,再批量处理

@Component
@Data
public class ExcelListener extends AnalysisEventListener<ExcelVo> {
   
    List<ExcelVo> list = new ArrayList<>();
    
    @Override
    public void invoke(ExcelVo excelVo, AnalysisContext analysisContext) {
   
        if (excelVo == null) {
   
            throw new RuntimeException("excel读取失败");
        }
        list.add(excelVo);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
   
        System.out.println("excel读取完成");
    }
}

向ExcelListener 传参

controller:接收文件接口

@RequestMapping(value = "/upload", method = RequestMethod.POST)
    public JsonResult upload(@RequestParam("file") MultipartFile file, @RequestParam("city") String city, @RequestParam("username") String username) {
   
        if (file.isEmpty()) {
   
            throw new RuntimeException("文件上传失败");
        }
        try {
   
            ExcelListener excelListener = new ExcelListener(namelistService, city, username);
            EasyExcel.read(file.getInputStream(), ExcelVo.class, excelListener).sheet().doRead();
            return true;
        } catch (Exception e) {
   
        }
    }

ExcelListener :通过构造函数重载,传入service层接口或其他参数

@Component
@Data
public class ExcelListener extends AnalysisEventListener<ExcelVo> {
   
    private NamelistService namelistService;
    private String city;
    private String username;

    public ExcelListener() {
   
    }

    public ExcelListener(NamelistService namelistService) {
   
        this.namelistService = namelistService;
    }

    public ExcelListener(NamelistService namelistService, String city, String username) {
   
        this.namelistService = namelistService;
        this.city = city;
        this.username = username;
    }

    @Override
    public void invoke(ExcelVo excelVo, AnalysisContext analysisContext) {
   
        if (excelVo == null) {
   
            throw new RuntimeException("excel读取失败");
        }
        namelistService.insertOne(excelVo,city,username);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
   
        System.out.println("excel读取完成");
    }
}

相关推荐

  1. golang读取json文件

    2023-12-15 06:14:03       63 阅读
  2. uniapp 读取本地文件

    2023-12-15 06:14:03       64 阅读
  3. python如何读取文件

    2023-12-15 06:14:03       43 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-15 06:14:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-15 06:14:03       101 阅读
  3. 在Django里面运行非项目文件

    2023-12-15 06:14:03       82 阅读
  4. Python语言-面向对象

    2023-12-15 06:14:03       91 阅读

热门阅读

  1. Android 修改状态栏背景半透明显示

    2023-12-15 06:14:03       57 阅读
  2. Angular 2 学习笔记

    2023-12-15 06:14:03       52 阅读
  3. Android笔记:SwipeRefreshLayout 自动刷新

    2023-12-15 06:14:03       51 阅读
  4. 数据仓库相关概念

    2023-12-15 06:14:03       67 阅读
  5. c语言多线程队列实现

    2023-12-15 06:14:03       54 阅读
  6. Redis—SpringDataRedis

    2023-12-15 06:14:03       40 阅读
  7. npm install -g node-gyp error -13

    2023-12-15 06:14:03       48 阅读
  8. conda保姆级使用教程

    2023-12-15 06:14:03       66 阅读