有时候我们需要进行一些excel表格的操作,不管是读取表格数据还是往表格写数据,之前都是使用poi去操作,需要自己获取流然后再一行一行的写,感觉还是有点麻烦,今天我们介绍一个使用起来比较方便的工具,就是easyexcel,下面我介绍一下基本用法,大家会发现对于一般的读写操作,会很方便

  1. 首先创建一个简单的maven工程,并将需要的依赖引入
<!--xls-->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>3.17</version>
</dependency>
<!--xlsx-->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>3.17</version>
</dependency>
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>2.1.1</version>
</dependency>
  1. 引入依赖后,就可以进行编码实践了,创建一个对应的简单实体类
public class DemoData {

    private Integer sno;

    private String sname;

    public DemoData(){}

    public DemoData(Integer sno, String sname) {
        this.sno = sno;
        this.sname = sname;
    }

    public Integer getSno() {
        return sno;
    }

    public void setSno(Integer sno) {
        this.sno = sno;
    }

    public String getSname() {
        return sname;
    }

    public void setSname(String sname) {
        this.sname = sname;
    }

    @Override
    public String toString() {
        return "DemoData{" +
                "sno=" + sno +
                ", sname='" + sname + '\'' +
                '}';
    }
}
  1. 然后创建一个测试类,先测试一些,写操作
public class TestEasyExcel {

    public static void main(String[] args) {
        //实现excel写操作
        //1 设置写入文件夹地址和excel文件名称
        String fileName = "/Users/liuzhenyu/workspace/exceltest/src/main/java/write.xlsx";
        //2 调用easyexcel里面的方法实现写操作
        //write方法两个参数:第一个参数文件路径名称,第二个参数实体类class
        EasyExcel.write(fileName, DemoData.class).sheet("学生列表").doWrite(getData());
    }

    //创建方法返回list集合
    private static List<DemoData> getData(){
        List<DemoData> list = new ArrayList<DemoData>();
        for(int i=0; i<10; i++){
            DemoData data = new DemoData(i,"lucy"+i);
            list.add(data);
        }

        return list;
    }
}
  1. 执行之后,去文件中看一下是否写进去了,可以看到完美写入,就是这么简单,哈哈
  2. java操作excel的按钮 java 操作excel的工具_java操作excel的按钮

  3. 下面我们来实现一下读的操作,正好读取我们刚刚写的那个文件,将读取的结果打印在控制台,相对于写操作,读操作还需要增加一个监听类,在监听类中获取表格的数据
public class ExcelListener extends AnalysisEventListener<DemoData> {

    //一行一行读取excel内容
    public void invoke(DemoData demoData, AnalysisContext analysisContext) {
        System.out.println("****"+demoData);
    }

    //读取表头内容
    @Override
    public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
        System.out.println("表头:" + headMap);
    }

    //读取完成之后
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        System.out.println("已读取完成");
    }
}
  1. 然后在测试类中只要加写两行代码就可以了
public class TestEasyExcel {

    public static void main(String[] args) {
        //实现excel写操作
        //1 设置写入文件夹地址和excel文件名称
        String fileName = "/Users/liuzhenyu/workspace/exceltest/src/main/java/write.xlsx";
        //2 调用easyexcel里面的方法实现写操作
        //write方法两个参数:第一个参数文件路径名称,第二个参数实体类class
        //EasyExcel.write(fileName, DemoData.class).sheet("学生列表").doWrite(getData());

        //实现excel读操作
        EasyExcel.read(fileName, DemoData.class, new ExcelListener()).sheet().doRead();
    }

    //创建方法返回list集合
    /*private static List<DemoData> getData(){
        List<DemoData> list = new ArrayList<DemoData>();
        for(int i=0; i<10; i++){
            DemoData data = new DemoData(i,"lucy"+i);
            list.add(data);
        }

        return list;
    }*/
}
  1. 看一下控制台显示,成功了,是不是很简单,快去试试吧