阿里EasyExcel使用

报错一:使用EasyExcel解析表格时报错ExcelAnalysisException: File type error,io must be available markSupported

https://blog.csdn.net/qq_42910468/article/details/103574522

1
InputStream inputStream = new BufferedInputStream(new FileInputStream(fileUrl));

  

 

开发

        <!-- 阿里开源EXCEL -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>2.1.6</version>
        </dependency>
复制代码
package com.power.manager;

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.power.manager.dto.WeekPowerLineLossExcelDto;
import org.junit.Test;

import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

public class EasyExcelTest {

    @Test
    public void importExcel() throws FileNotFoundException {
        String url = "E:\\test\\test\\202002\\2002xiansun.xls";
        InputStream is = new BufferedInputStream(new FileInputStream(url));

        final int CAPACITY = 5000;
        List<WeekPowerLineLossExcelDto> list = new ArrayList<>(CAPACITY);

        System.out.println("开始");
        EasyExcel.read(is, WeekPowerLineLossExcelDto.class, new AnalysisEventListener<WeekPowerLineLossExcelDto>() {

            @Override
            public void invoke(WeekPowerLineLossExcelDto dto, AnalysisContext analysisContext) {
                list.add(dto);
                if(list.size() >= CAPACITY){
                    System.out.println(list.size());
                    list.clear();
                }
            }

            @Override
            public void doAfterAllAnalysed(AnalysisContext analysisContext) {
                System.out.println("最终剩余:" + list.size());
                list.clear();//解析结束销毁不用的资源
            }
        }).sheet().doRead();
        System.out.println("结束");
    }
}
复制代码
复制代码
package com.power.manager.dto;

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

/**
 * 参考:https://juejin.im/post/5dae4fdd51882554c07585d1
 * 导入
 */
@Data
public class WeekPowerLineLossExcelDto {
    //序号
    @ExcelProperty(index = 0)
    private Integer num;

    @ExcelProperty(index = 1)
    private String countDate;   

    @ExcelProperty(index = 2)
    private String powerSupplyCompanyName; 

}
复制代码

 

运行结果:

开始

5000
5000
5000
最终剩余:1308
结束

posted @   Peter.Jones  阅读(781)  评论(0编辑  收藏  举报
编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
历史上的今天:
2019-03-10 Maven的<profile>标签的使用
点击右上角即可分享
微信分享提示