java学习笔记----EasyExcel 实现 Excel数据的导入导出

1,629 阅读1分钟

编写匹配 Excel表格中数据的实体类

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

@Data
public class Stu {

    //设置表头名称 索引
    @ExcelProperty(value = "学生编号",index = 0)
    private int sno;

    //设置表头名称 索引
    @ExcelProperty(value = "学生姓名",index = 1)
    private String sname;

}

maven引入依赖

<dependencies>
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>easyexcel</artifactId>
        <version>2.1.6</version>
    </dependency>
</dependencies>

向Excel写入数据demo【封装的假数据 正常情况下 应该是从数据库查询】

import com.alibaba.excel.EasyExcel;
import com.atguigu.cmn.test.entity.Stu;

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

public class WriteTest {
    public static void main(String[] args) {
        String fileName = "E:\11.xlsx";
        
        //文件路径 或 输入输出流  实体类           模板名称
        EasyExcel.write(fileName,Stu.class).sheet("学生信息")
                //要写入的数据 
                .doWrite(data());
    }

    //循环设置要添加的数据,最终封装到list集合中
    private static List<Stu> data() {
        List<Stu> list = new ArrayList<Stu>();
        for (int i = 0; i < 10; i++) {
            Stu data = new Stu();
            data.setSno(i);
            data.setSname("张三"+i);
            list.add(data);
        }
        return list;
    }
}

插入的数据

image.png

读取Excel数据demo【需要整合 读取监听器】

ExcelReadListener 监听器 用于从 Excel读取数据

import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.atguigu.cmn.test.entity.Stu;


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

public class ExcelReadListener extends AnalysisEventListener<Stu> {

    //创建List集合 保存读取的数据
    List<Stu> list = new ArrayList<>();

    //一行一行的 读取excel内容  在这里可以操作向数据库插入数据
    @Override
    public void invoke(Stu stu, AnalysisContext analysisContext) {
        System.out.println("stu读到的行 = " + stu);
        list.add(stu);
    }

    //读取表头信息   当前方法  比读取信息的方法 先执行
    @Override
    public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
        System.out.println("表头信息"+headMap);
    }

    //读取完后 执行
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        System.out.println("读取数据完成");
    }
}

读取数据的代码

import com.alibaba.excel.EasyExcel;
import com.atguigu.cmn.test.entity.Stu;

public class ReadTest {
    public static void main(String[] args) {
        String fileName = "E:\11.xlsx";
        //参数 文件路径             实体类    监听器 里面
        EasyExcel.read(fileName, Stu.class, new ExcelReadListener()).sheet()
                .doRead();
    }
}

读取到的数据 image.png

官网的地址 Alibaba Easy Excel - 简单、省内存的Java解析Excel工具 | 首页 (alibaba-easyexcel.github.io)