EasyExcel实现excel的读写操作

本文介绍了如何使用阿里巴巴的EasyExcel库在Java中进行Excel数据的读写。首先,通过引入EasyExcel的依赖,然后定义表头对应的实体类`DemoData`。接着,展示了如何执行写入操作,将数据写入到Excel文件中。最后,通过创建监听类`ExcelListener`实现了读取Excel内容,并展示了读取和处理数据的过程。
摘要由CSDN通过智能技术生成

1.导入EasyExcel依赖

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

2.建立表头对应的实体类

package com.atgugui.excel;

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

@Data
public class DemoData {

    @ExcelProperty(value = "学生编号", index = 0)
    private Integer sno;

    @ExcelProperty(value = "学生姓名", index = 1)
    private String sname;
}


3.执行写入excel操作

package com.atgugui.excel;

import com.alibaba.excel.EasyExcel;

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

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

    private static List<DemoData> getData() {
        List<DemoData> list = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            DemoData data = new DemoData();
            data.setSno(i);
            data.setSname("lucy" + i);
            list.add(data);
        }
        return list;
    }
}

最终效果演示:

在这里插入图片描述

4.执行读入操作,实现一个监听类

package com.atgugui.excel;

import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.alibaba.excel.metadata.CellData;

import java.util.Map;

public class ExcelListener extends AnalysisEventListener<DemoData> {
    //一行一行读取excel的内容
    @Override
    public void invoke(DemoData demoData, AnalysisContext analysisContext) {
        System.out.println("***" + demoData);
    }
    //读取完成之后
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {

    }

    @Override
    public void invokeHead(Map<Integer, CellData> headMap, AnalysisContext context) {
        System.out.println("表头:" + headMap);
    }
}

5.执行读入操作

package com.atgugui.excel;

import com.alibaba.excel.EasyExcel;

public class TestReadEasyExcel {
    public static void main(String[] args) {
        // 实现excel操作
        String filename = "F:\\test.xlsx";
        EasyExcel.read(filename, DemoData.class, new ExcelListener()).sheet().doRead();
    }
}

6.读入效果演示

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
EasyExcel是一个基于Java的简单易用的Excel文件读写工具,它可以很方便地实现Excel文件导入和导出。下面介绍一下如何使用EasyExcel实现Excel文件导出。 1. 引入EasyExcel依赖 将以下依赖添加到项目的pom.xml文件中: ```xml <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>2.1.7</version> </dependency> ``` 2. 创建Excel实体类 首先,需要创建一个Java类来表示Excel文件的数据结构。例如,如果要导出一个包含学生信息的Excel文件,可以创建一个名为Student的类,并在其中定义需要导出的属性: ```java public class Student { private String name; private Integer age; private String gender; private String address; // 省略getter和setter方法 } ``` 3. 创建Excel文件 在进行Excel文件导出之前,需要先创建一个Excel文件。EasyExcel提供了一个名为ExcelWriter的类,可以用来创建Excel文件。以下是一个创建Excel文件的示例代码: ```java // 创建ExcelWriter对象 ExcelWriter excelWriter = new ExcelWriter(new FileOutputStream("students.xlsx"), ExcelTypeEnum.XLSX); // 创建Sheet对象 Sheet sheet = new Sheet(1, 0, Student.class); // 设置Sheet名称 sheet.setSheetName("学生信息"); // 写入数据 List<Student> data = new ArrayList<>(); // 添加数据到List中 // ... excelWriter.write(data, sheet); // 关闭ExcelWriter对象 excelWriter.finish(); ``` 以上代码中,创建了一个名为“学生信息”的Sheet对象,并设置其数据类型为Student类。然后,将需要导出的数据写入到Excel文件中。 4. 导出Excel文件 创建Excel文件后,就可以通过EasyExcel将其导出了。以下是一个导出Excel文件的示例代码: ```java // 设置响应头信息 response.setContentType("application/vnd.ms-excel"); response.setCharacterEncoding("utf-8"); response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode("students.xlsx", "UTF-8")); // 创建ExcelWriter对象 ExcelWriter excelWriter = new ExcelWriter(response.getOutputStream(), ExcelTypeEnum.XLSX, true); // 创建Sheet对象 Sheet sheet = new Sheet(1, 0, Student.class); // 设置Sheet名称 sheet.setSheetName("学生信息"); // 写入数据 List<Student> data = new ArrayList<>(); // 添加数据到List中 // ... excelWriter.write(data, sheet); // 关闭ExcelWriter对象 excelWriter.finish(); ``` 以上代码中,设置了响应头信息,告诉浏览器需要下载一个Excel文件。然后,创建了一个ExcelWriter对象,并将其输出流设置为响应流,这样Excel文件就可以直接输出到浏览器中。最后,将需要导出的数据写入到Excel文件中,并关闭ExcelWriter对象。 通过以上步骤,就可以使用EasyExcel实现Excel文件导出了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

柯小帅

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值