栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Spring Boot读取Excel表格快速上手

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Spring Boot读取Excel表格快速上手

最简单容易上手的EasyExcel 1.导入依赖

2.编写监听器

```java
package com.yumchina.cultivate.config;

import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.yumchina.cultivate.pojo.DscStudent;
import com.yumchina.cultivate.service.ExcelService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;

import java.util.ArrayList;
import java.util.List;


@Slf4j
@Component
public class ExcelListener extends AnalysisEventListener {

    
    private static final int BATCH_COUNT = 20;
    private List cachedDataList = new ArrayList<>(BATCH_COUNT+2);
    
    private final ExcelService excelService;

    public ExcelListener(ExcelService excelService) {
        this.excelService = excelService;
    }

    
    @Override
    public void invoke(Student Student, AnalysisContext analysisContext) {
//        log.info("解析到一条数据:{}", JSON.toJSonString(dscStudent));
        cachedDataList.add(dscStudent);
        // 达到BATCH_COUNT了,需要去存储一次数据库,防止数据几万条数据在内存,容易OOM
        if (cachedDataList.size() >= BATCH_COUNT) {
//            saveData();
            // 存储完成清理 list
            cachedDataList = new ArrayList<>(BATCH_COUNT+2);
        }
    }

    
    @Override
    public void doAfterAllAnalysed(AnalysisContext context) {
        // 这里也要保存数据,确保最后遗留的数据也存储到数据库
//        saveData();
        log.info("所有数据解析完成!");
    }

    
//    private void saveData() {
//        log.info("{}条数据,开始存储数据库!", cachedDataList.size());
//        excelService.readExcelAndCopyDatabase(cachedDataList);
//        log.info("存储数据库成功!");
//    }
    public List getData(){
        return cachedDataList;
    }
}

3编写控制器
@PostMapping("/readStudentExcel")
    public Result readStudentExcel(MultipartFile file){
        try {
        //固定写 DscStudent换成自己的实体类
            EasyExcel.read(file.getInputStream(), DscStudent.class,excelListener).sheet().doRead();
        } catch (IOException e) {
            e.printStackTrace();
        }
        List data = excelListener.getData();
        for (DscStudent dscStudent:data){
            System.out.println(dscStudent.getStudentName().toString());
        }
        return Result.ok();
    }
4编写pojo
public class Student implements Serializable {
    @ExcelProperty(value = "学生姓名")
    private String studentName;
    private static final long serialVersionUID = 1L;

}
下载Excel
@GetMapping("/reportExcel")
    public void reportExcel(String startTime, String endTime, HttpServletResponse response) throws IOException {
        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("utf-8");
        //防止中文乱码
        String fileName = URLEncoder.encode("Employeetraintime", "UTF-8");
        //插入自己的查询语言
        //List employeetraintimes = excelService.reportExce(startTime, endTime);
        response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");
        //EmployeeTrainTimeVo 为对应的实体类对象
        EasyExcel.write(response.getOutputStream(),EmployeeTrainTimeVo.class).sheet("新工工时").doWrite(employeetraintimes);
    }
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/696703.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号