IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Java使用EasyExcel实现对excel的读和写操作(导出和导入) -> 正文阅读

[Java知识库]Java使用EasyExcel实现对excel的读和写操作(导出和导入)

前言

前言:记录如何使用Java来实现对excel的读和写操作,用的是阿里封装的EasyExcel,使用起来非常的方便和简洁。

操作语言:Java8
工具:IDEA
项目结构:maven项目

强调:该文章虽然写的是对excel的读和写,但其实导出操作本质上也是往excel写入数据,而导入操作就是读取excel中的数据来展示到页面(或者是新增数据),所以在实际开发中,也是可以将这套操作应用到导入和导出的。

目的:该文章求的是步骤详细、过程简单,保证小白也能操作成功,希望能帮到大家~


1、EasyExcel是什么?

  • Java领域解析、生成Excel比较有名的框架有Apache poi、jxl等。但他们都存在一个严重的问题就是非常的耗内存。如果你的系统并发量不大的话可能还行,但是一旦并发上来后一定会OOM或者JVM频繁的full gc。
  • EasyExcel是阿里巴巴开源的一个excel处理框架,以使用简单、节省内存著称。EasyExcel能大大减少占用内存的主要原因是在解析Excel时没有将文件数据一次性全部加载到内存中,而是从磁盘上一行行读取数据,逐个解析。
  • EasyExcel采用一行一行的解析模式,并将一行的解析结果以观察者的模式通知处理(AnalysisEventListener)。

应用场景

1、数据导入:减轻录入工作量
2、数据导出:统计信息归档
3、数据传输:异构系统之间数据传输

2、环境搭建

1、创建一个普通的maven项目
2、在pom中引入相关依赖

<dependencies>
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>easyexcel</artifactId>
        <version>2.1.1</version>
    </dependency>
    
	 <!--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>
      
      <!--lombok用来简化实体类:需要安装lombok插件-->
      <dependency>
           <groupId>org.projectlombok</groupId>
           <artifactId>lombok</artifactId>
       </dependency>
   
</dependencies>

3、创建实体类

//设置表头和添加的数据字段
@Data
public class DemoData {
    //设置表头名称
    @ExcelProperty("学生编号")
    private int sno;
    
	//设置表头名称
    @ExcelProperty("学生姓名")
    private String sname;
}

3、实现excel写操作

1、创建一个测试类,在该类中创建方法循环设置要添加到Excel的数据

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

2、实现最终的添加操作

 @Test
 public void test1() {
     //实现excel写的操作
     //1、设置写入文件夹地址和excel文件名称
     String fileName = "E:\\write.xlsx";

     //2、调用EasyExcel里面方法实现写的操作
     //write两个参数:参数1:文件路径名称   参数2:参数实体类class
     EasyExcel.write(fileName,DemoData.class).sheet("学生列表").doWrite(getData());
 }

3、运行该Test,去到指定路径查看生成的文件,写入成功~
在这里插入图片描述

4、实现excel读操作

创建一个excel表格(为了方便可以直接拿上面自动生成的excel表格数据)在这里插入图片描述

1、创建接受数据的实体类

@Data
public class DemoData {

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

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

2、创建读取操作的监听器

public class ExcelListener extends AnalysisEventListener<DemoData> {

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

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

    //读取完之后执行
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        System.out.println("读完啦、。。。,");
    }
}

3、调用实现最终的读取

//实现excel读的操作
@Test
public void test2() {
   String fileName = "E:\\write.xlsx";//要读excel文件位置
   EasyExcel.read(fileName,DemoData.class,new ExcelListener()).sheet().doRead();
}

4、运行成功,看控制台,可以看到数据已经全部读取到了(数据都取到了,此时啥操作做不了呢~)在这里插入图片描述


总结

在操作过程中如有不懂或遇到啥困难,可在下方留言,作者看到会在第一时间回复~

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-04-29 11:57:32  更:2022-04-29 12:01:39 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 1:50:37-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码