Java导入Excel步骤

简单的导入Excel步骤

一、写实体类

	@Data
@ExcelIgnoreUnannotated
@ContentRowHeight(20)
@HeadRowHeight(20)
@ColumnWidth(25)
public class Student {
    @ExcelProperty("姓名")
    private String name;

    @ExcelProperty("年龄")
    private Integer age;
}

二、写监听类

创建的监听类需要Extens AnalysisEventListener类,类中的范型是要解析的实体类。此处以Student类为例。
监听类中的Service是没法使用@Autowired注解通过Spring管理的,如果导入后要用到service,需要在构造函数的参数中传入Service。
监听类中的invoke和doAfterAllAnalysed方法分别对应解析每条数据后执行的操作,和解析完全部数据执行的操作。当读取到数据后需要对数据进行处理时,应在这两个方法中写执行语句。

@Slf4j
public class StudentImportListener extends AnalysisEventListener<Student> {
    /**
     * 每隔5条存储数据库,方便内存回收
     */
    private static final int BATCH_COUNT = 5;
    List<Student> list = new ArrayList<>();

    private void showResult(){
        //展示获取到的数据
        System.out.println("从excel中获取到的数据:");
        for (Student student : list) {
            System.out.println("student = " + student);
        }
    }

    //无参构造方法
    public StudentImportListener() {

    }

    /**
     * 这个每一条数据解析都会来调用
     */
    @Override
    public void invoke(Student student, AnalysisContext analysisContext) {
        log.info("解析到一条数据:{}",student);
        list.add(student);
        // 达到BATCH_COUNT了,需要去存储一次数据库,防止数据几万条数据在内存,容易OOM
        if (list.size() >= BATCH_COUNT) {
            showResult();
            // 存储完成清理list
            list.clear();
        }
    }

    /**
     * 所有数据解析完成了 都会来调用
     */
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        showResult();
        System.out.println("所有数据解析完成!");
    }
}

三、写导入方法

获取要读取的文件的位置
执行EasyExcel的read方法,其中,第一个参数是文件的路径,第二个参数是要解析的实体类(此处为我们创建的Student类),第三个参数是刚才创建的监听器类。

/**
     * 导入Execl
     */
    @Test
    public void importExcelTest(){
        // 1.获得要读取的文件的位置
        String path = "src/main/resources/excel/";
        String fileName = "importExample.xlsx";
        String name = path + fileName;
        // 2.读文件
        EasyExcel.read(name,Student.class,
        new StudentImportListener()).sheet().doRead();
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值