springboot 使用EasyExcel 读取所有sheet内容

需求

上传一个excel,读取所有sheet的内容,并根据每个sheet的命名处理其对应的数据

添加依赖

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

每行数据对应的实体类

import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;
import lombok.ToString;

import java.math.BigDecimal;
import java.util.Date;

@Data
@ToString
public class RecordImportBean {

    /**
     * 一个对象要么只用index,要么只用name去匹配
     */
    @ExcelProperty(index = 0)
    private String name;
//    /**
//     * 用名字去匹配,这里需要注意,如果名字重复,会导致只有一个字段读取到数据
//     */
//    @ExcelProperty(value = "名称")
//    private String name;

    @ExcelProperty(index = 1)
    private BigDecimal number;

    @ExcelProperty(index = 2)
    private Date createTime;

    @ExcelProperty(index = 3)
    private String script;
}

读取监听器

    /**
     * 自定义监听器
     */
    class CustomExcelListener extends AnalysisEventListener<RecordImportBean> {

        private List<RecordImportBean> dataList = new ArrayList<>();

        @Override
        public void invoke(RecordImportBean recordImportBean, AnalysisContext analysisContext) {
            dataList.add(recordImportBean);
        }

        @Override
        public void doAfterAllAnalysed(AnalysisContext analysisContext) {
            // 在这里处理完所有数据后的逻辑,如果不需要可以删除
        }

        public List<RecordImportBean> getDataList() {
            return dataList;
        }
    }

 Controller

    @PostMapping("importFromExcel")
    @ApiOperation(value = "从excel导入", notes = "")
    public Result importFromExcel(@RequestParam("file") MultipartFile file) {
        return tRecordService.importFromExcel(file);
    }

Service实现

    @Override
    public Result importFromExcel(MultipartFile file) {
        try {

            InputStream fileInputStream = file.getInputStream();
            // 读取Excel文件
            ExcelReaderBuilder readerBuilder = EasyExcel.read(fileInputStream);
            ExcelReader excelReader = readerBuilder.build();
            ExcelReadExecutor excelReadExecutor = excelReader.excelExecutor();
            List<ReadSheet> sheets = excelReadExecutor.sheetList();

            //读取到的数据
            Map<String, List<RecordImportBean>> sheetData = new HashMap<>();
            for (ReadSheet sheet : sheets) {
                CustomExcelListener listener = new CustomExcelListener();
                ReadSheet readSheet1 = EasyExcel.readSheet(sheet.getSheetNo()).head(RecordImportBean.class).registerReadListener(listener).build();
                excelReader.read(readSheet1);
                // 得到sheet名称和其对应的数据
                sheetData.put(sheet.getSheetName(), listener.getDataList());
            }

            return ResultTool.success();
        } catch (IOException e) {
            e.printStackTrace();
            log.error("导入数据出错:"+e.getMessage());
            return  ResultTool.fail();
        }
    }

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个在Spring Boot中提供公共方法的示例: ```java @Service public class ExcelService { // 定义Excel的列名 private static final String[] HEADERS = {"列1", "列2", "列3"}; // 上传Excel文件并读取数据 public List<Map<String, Object>> readExcel(MultipartFile file) throws IOException { InputStream inputStream = file.getInputStream(); List<Map<String, Object>> dataList = new ArrayList<>(); // 读取Excel文件 EasyExcel.read(inputStream) .headRowNumber(1) // 从第2行开始读取数据 .registerReadListener(new ReadListener() { @Override public void onReadSheet(int sheetIndex, String sheetName, int totalRowNumber) { // 读取Sheet的信息 } @Override public void onReadRowData(int sheetIndex, int rowIndex, List<String> rowData) { // 读取每行的数据 Map<String, Object> dataMap = new HashMap<>(); for (int i = 0; i < HEADERS.length; i++) { dataMap.put(HEADERS[i], rowData.get(i)); } dataList.add(dataMap); } }) .sheet() .doRead(); return dataList; } } ``` 在上面的代码中,我们在`ExcelService`服务类中定义了一个`readExcel`方法,该方法可以读取上传的Excel文件并返回一个`List<Map<String, Object>>`类型的数据。 为了在Spring Boot使用这个服务类,我们需要在`ExcelService`类上添加`@Service`注解,然后在需要使用该服务的类中注入它,例如: ```java @RestController public class MyController { @Autowired private ExcelService excelService; @PostMapping("/uploadExcel") public List<Map<String, Object>> uploadExcel(@RequestParam("file") MultipartFile file) throws IOException { return excelService.readExcel(file); } } ``` 在上面的代码中,我们定义了一个`MyController`控制器类,并在其中注入了`ExcelService`服务。然后,我们在`/uploadExcel`接口中接收上传的Excel文件,并调用`ExcelService`的`readExcel`方法来读取数据并返回。当然,你需要根据实际情况修改代码。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值