EasyExcel知识【Java程序进行读写生成Excel操作】

这篇具有很好参考价值的文章主要介绍了EasyExcel知识【Java程序进行读写生成Excel操作】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

  • 💂 个人主页: 爱吃豆的土豆
  • 🌈欢迎加入社区,福利多多哦!土豆社区

  • 🤟数据库专栏更新完毕:数据库知识
  • 🤟JDBC专栏更新完毕:JDBC知识
  • 🤟Mybatis专栏更新完毕:Mybatis知识
  • 💬 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦

目录

1,Easy Excel入门

1.1:Easy Excel概述

1.2:Easy Excel特点

1.3:环境搭建

1.3.1:测试父项目

1.3.2:测试excel项目

1.4:基本操作

1.4.1:测试JavaBean

1.4.2:测试文件路径

1.4.3:写入操作

1.4.4:读出操作

1.5:复杂操作

1.5.1:复合表头

1.5.2:写操作:多表

1.5.3:读操作:多表

1.5.4:写操作:多对象


1,Easy Excel入门

1.1:Easy Excel概述

 EasyExcel是一个基于Java的简单、省内存的读写Excel的开源项目。在尽可能节约内存的情况下支持读写百M的Excel工具。

官网:EasyExcel官方文档 - 基于Java的Excel处理工具 | Easy Excel

github地址:GitHub - alibaba/easyexcel: 快速、简洁、解决大文件内存溢出的java处理Excel工具

1.2:Easy Excel特点

Java解析、生成Excel比较有名的框架有Apache poi、jxl,但他们都存在一个严重的问题就是非常的耗内存。

EasyExcel 重写了poi,使一个3M的excel只需要几M内存,并且再大的excel不会出现内存溢出。

64M内存1分钟内读取75M(46W行25列)的Excel。

1.3:环境搭建

1.3.1:测试父项目

项目名:zx-test-parent

EasyExcel知识【Java程序进行读写生成Excel操作】

  • 修改pom文件

 

<dependencies>
    <!--测试-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-amqp</artifactId>
    </dependency>
</dependencies>

1.3.2:测试excel项目

项目名:zx-test-excel  

EasyExcel知识【Java程序进行读写生成Excel操作】

 

修改pom,添加依赖

<dependencies>
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>easyexcel</artifactId>
        <version>3.1.1</version>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
    </dependency>
</dependencies>

 

EasyExcel知识【Java程序进行读写生成Excel操作】 

1.4:基本操作

EasyExcel知识【Java程序进行读写生成Excel操作】 

1.4.1:测试JavaBean

常用的注解:

EasyExcel知识【Java程序进行读写生成Excel操作】

 

@Data
@AllArgsConstructor
@NoArgsConstructor
@ColumnWidth(30)
@HeadRowHeight(30)
public class Student1 {
    @ExcelProperty("编号")
    private String id;
    @ExcelProperty("姓名")
    @ContentFontStyle(fontName = "楷体",italic = BooleanEnum.TRUE,color = Font.ITALIC)
    private String name;
    @ExcelProperty({"基本信息","年龄"})
    private Integer age;
    @ExcelProperty({"基本信息","电话"})
    private String phone;
    @ExcelProperty({"可选信息","邮件"})
    private String Email;
    @ExcelProperty({"可选信息","生日"})
    @DateTimeFormat("yyyy-MM-dd HH:mm")
    private Date birthday;

}

1.4.2:测试文件路径

    public String path(){
        return this.getClass().getResource("/").getPath();
    }

1.4.3:写入操作

  • excel 属于 office组件一个软件

  • 存在若干版本,大体上划分2种情况,2007前的,2007年后的

    • 2003版:扩展名 xls,内容比较少,最大单元格 IV65536 ,256列(IV)

    • 2007版:扩展名 xlsx,内容较多,最大单元格 XFD1048576,16384列(XFD)

   // 模拟数据
    public List<Student1> getDate(){
        //模拟十条数据
        ArrayList<Student1> student1s = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            Student1 student1 = new Student1(i+"","土豆"+i,i,"115"+i,"626"+i,new Date());
            student1s.add(student1);
        }
        return student1s;
    }
    //创建测试写程序
    @Test
    public void testWrite(){
        //写入位置:%classpath%/
        //文件名称:student-demo.xls
        //表名:土豆
        //1,文件位置
        String file = path()+"student_demo1.xls";
        //2 写操作
        EasyExcel.write(file, Student1.class).sheet("土豆").doWrite(getDate());
    }

1.4.4:读出操作

处理类:

  • 处理类需要实现 AnalysisEventListener 接口

package com.czxy.read;

import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.czxy.excel.Student1;

public class StudentDataListener1 extends AnalysisEventListener<Student1> {

    @Override
    public void invoke(Student1 student1, AnalysisContext analysisContext) {
        System.out.println(student1);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {

    }
}
 //测试读出excel程序
    @Test
    public void testRead(){
        String file = path()+"student_demo1.xls";
        //读操作
        EasyExcel.read(file, Student1.class, new StudentDataListener1()).sheet("土豆").doRead();
    }

1.5:复杂操作

1.5.1:复合表头

package com.czxy.excel;

import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.format.DateTimeFormat;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.alibaba.excel.annotation.write.style.ContentFontStyle;
import com.alibaba.excel.annotation.write.style.HeadRowHeight;
import com.alibaba.excel.enums.BooleanEnum;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.awt.*;
import java.util.Date;

@Data
@AllArgsConstructor
@NoArgsConstructor
@ColumnWidth(30)
@HeadRowHeight(30)
public class Student2 {
    @ExcelProperty("编号")
    private String id;
    @ExcelProperty("姓名")
    @ContentFontStyle(fontName = "楷体",italic = BooleanEnum.TRUE,color = Font.ITALIC)
    private String name;
    @ExcelProperty({"基本信息","年龄"})
    private Integer age;
    @ExcelProperty({"基本信息","电话"})
    private String phone;
    @ExcelProperty({"可选信息","邮件"})
    private String Email;
    @ExcelProperty({"可选信息","生日"})
    @DateTimeFormat("yyyy-MM-dd HH:mm")
    private Date birthday;

}

1.5.2:写操作:多表

 //得到根目录路径
    public String path(){
        return this.getClass().getResource("/").getPath();
    }
    // 模拟数据
    public List<Student1> getDate(){
        //模拟十条数据
        ArrayList<Student1> student1s = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            Student1 student1 = new Student1(i+"","土豆"+i,i,"115"+i,"626"+i,new Date());
            student1s.add(student1);
        }
        return student1s;
    }
    //创建测试书写多表
    @Test
    public void testWrite(){
        //写入位置:%classpath%/
        //文件名称:student-demo.xls
        //表名:土豆
        //1,文件位置
        String file = path()+"student_demo2.xls";
        //2 写操作
        ExcelWriter excelWriter = EasyExcel.write(file, Student2.class).build();
        //写入多个sheet
        WriteSheet writeSheet1 = EasyExcel.writerSheet("爱吃豆的").build();
        excelWriter.write(getDate(),writeSheet1);
        //写入第二个sheet
        WriteSheet writeSheet2 = EasyExcel.writerSheet("土豆").build();
        excelWriter.write(getDate(),writeSheet2);
        excelWriter.finish();
    }

1.5.3:读操作:多表

具有缓存处理类

package com.czxy.read;

import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.czxy.excel.Student2;

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

public class StudentDataListener2 extends AnalysisEventListener<Student2> {

    //创建一个集合用于保存学生
    private List<Student2> student2List = new ArrayList<>();
    //创建一个变量用于判断
    private Integer size = 4;
    @Override
    public void invoke(Student2 student2, AnalysisContext analysisContext) {
        student2List.add(student2);
        if (student2List.size()>size){
            print();
        }
    }
    //重新创建一个方法
    public void print(){
            student2List.forEach(System.out::println);
        System.out.println("============");
        //打印完成之后进行清空集合
        student2List.clear();
    }
    //该方法
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        System.out.println("打印完成");
        //如果集合中还有数据进行打印
       if (!student2List.isEmpty()){
           print();
       }
       student2List.clear();
    }
}

读操作 

    @Test
    public void testRead(){
        String file = path()+"student_demo2.xls";
        //读操作
        ExcelReader excelReader = EasyExcel.read(file, Student2.class, new StudentDataListener2()).build();
        ReadSheet readSheet1 = EasyExcel.readSheet("爱吃豆的").build();
        excelReader.read(readSheet1);
        ReadSheet readSheet2 = EasyExcel.readSheet("土豆").build();
        excelReader.read(readSheet2);
        excelReader.finish();
    }

1.5.4:写操作:多对象

Student

@Data
@NoArgsConstructor
@AllArgsConstructor
public class Student {
    @ExcelProperty("姓名")
    private String name;
    @ExcelProperty("年龄")
    private Integer age;
}

Book

@Data
@NoArgsConstructor
@AllArgsConstructor
@HeadRowHeight(50)
@HeadFontStyle(fontName = "黑体",italic =  BooleanEnum.TRUE, color = Font.COLOR_RED, underline = 2)
public class Book {
    @ExcelProperty("编号")
    private String id;

    @ExcelProperty({"作者信息","姓名"})
    private String authorName;

    @ExcelProperty({"作者信息","年龄"})
    private Integer authorAge;

    @ExcelProperty({"书籍基本信息","标题"})
    private String title;

    @ContentFontStyle(fontName = "楷书",italic =  BooleanEnum.TRUE, color = Font.COLOR_RED, underline = -1)
    @ExcelProperty({"书籍基本信息","价格"})
    private Double price;
    @ExcelProperty({"书籍基本信息","出版日期"})
    @DateTimeFormat("yyyy年MM月dd日")
    private Date publishDate;
}

 实现文章来源地址https://www.toymoban.com/news/detail-400509.html

public class TestManyObject {

    // 获得当前项目的运行时的根目录
    public String getPath() {
        return this.getClass().getResource("/").getPath();
    }

    // 模拟数据
    public List<Student> getStudentData() {
        List<Student> list = new ArrayList<>();
        for (int i = 0; i < 20; i++) {
            list.add(new Student("张三" + i, 18 + i));
        }
        return list;
    }

    public List<Book> getBookData() {
        List<Book> list = new ArrayList<>();
        for (int i = 0; i < 20; i++) {
            list.add(new Book(i+"" , "张三" + i , 18 +i, "坏蛋是怎么"+i, 998d+i, new Date()));
        }
        return list;
    }

    // 遍历map即可
    private Map<Class<?>, List<?>> getData() {
        Map<Class<?>, List<?>> map = new HashMap<>();
        map.put(Student.class, getStudentData());
        map.put(Book.class, getBookData());
        return map;
    }

    @Test
    public void testManyObject() {
        String file = getPath() + "many_object.xlsx";
        //1 开始写
        ExcelWriter excelWriter = EasyExcel.write(file).build();
        //2 依次写每一个对象
        for(Map.Entry<Class<?>, List<?>> entry : getData().entrySet()) {
            Class<?> clazz = entry.getKey();            //类型
            List<?> data = entry.getValue();            //数据
            WriteSheet writeSheet = EasyExcel.writerSheet(clazz.getSimpleName()).head(clazz).build();
            excelWriter.write(data, writeSheet);
        }

        //3 写完成
        excelWriter.finish();
    }
}

到了这里,关于EasyExcel知识【Java程序进行读写生成Excel操作】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 记录java使用EasyExcel进行单元格内换行操作

    1、首先是在需要换行的地方将 n   或者 rn 替换为 String.valueOf((char)10)  ,有时候不替换好像也能用 2、第一步完成后可能导出的内容还是无法换行,需要双击单元格才会换行, 在导出的java实体类上加入注解 @ContentStyle( horizontalAlignment = HorizontalAlignmentEnum.CENTER, verticalAlignmen

    2023年04月08日
    浏览(27)
  • Spring Boot 引入 easyexcel 最新版本 3.3.2,实现读写 Excel

    EasyExcel是一个基于Java的、快速、简洁、解决大文件内存溢出的Excel处理工具。 他能让你在不用考虑性能、内存的等因素的情况下,快速完成Excel的读、写等功能 在 Spring Boot 环境中使用 easyexcel,需要完成以下几个步骤 pom.xml中引入easyexcel的依赖,此处版本号3.3.2 建立一个实体

    2024年02月11日
    浏览(18)
  • Java 基于Apache POI实现Excel读写操作

    Win10 Java JDK1.8 pom.xml配置 代码实现 exmple.xml 补充说明 创建工作簿 POI创建工作簿的API有3种: HSSFWorkbook : 此API用于操作Excel 2003及之前的版本(文件扩展名 .xls ),优点是导出速度快,缺点是导出的行数有局限性,最多为65535行,超出65536条后系统就会报错。对内存消耗比较大,容

    2024年02月15日
    浏览(22)
  • 90天玩转Python—11—基础知识篇:Python自动化操作Excel:读写、增删改查、分组统计全攻略

    90天玩转Python—01—基础知识篇:C站最全Python标准库总结 90天玩转Python--02--基础知识篇:初识Python与PyCharm 90天玩转Python—03—基础知识篇:Python和PyCharm(语言特点、学习方法、工具安装) 90天玩转Python—04—基础知识篇:Python编程基础:标识符、保留字、注释、多行语句、p

    2024年04月11日
    浏览(24)
  • 30 使用easyExcel依赖生成Excel

            在类上加注解,@ExcelProperty,注解中value属性是列名,index属性是第几列。         首先,需要创建一个泛型为Student的集合,存放多个Student对象,一个对象相当于excel表格的其中一行。然后,调用EasyExcel的write方法,需要填写excel生成的路径(需要写到生成的excel文件

    2024年02月14日
    浏览(20)
  • EasyExcel读模板生成excel文件&注解Bean生成文件

    EasyExcel依赖 apache poi依赖         EasyExcel同时依赖Apache POI库,同时还需要注意下两个库的版本对应关系。EasyExcel可能升级对poi的依赖,导致功能不兼容。 EasyExcel注解部分参考:EasyExcel注解大全_起一个让人印象深刻的名字的博客-CSDN博客 2.3、生成结果展示 注意! 占位符的

    2024年02月10日
    浏览(17)
  • 使用EasyExcel对excel数据进行相似度判断

         

    2024年02月09日
    浏览(36)
  • Spring Boot集成EasyExcel实现excel导入导出操作

    Easy Excel 官网 Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及解压后存储都是在内存中完成的,内存消耗依然很

    2024年02月14日
    浏览(24)
  • java处理Excel表格(EasyExcel)

    1.EasyExcel特点 Java领域解析、生成Excel比较有名的框架有Apache poi、jxl等。但他们都存在一个严重的问题就是非常的耗内存。如果你的系统并发量不大的话可能还行,但是一旦并发上来后一定会OOM或者JVM频繁的full gc。 EasyExcel是阿里巴巴开源的一个excel处理框架,以使用简单、节

    2024年02月15日
    浏览(27)
  • Java 使用 easyexcel 读取 excel 文件

    easyexcel 官网:EasyExcel官方文档 - 基于Java的Excel处理工具 | Easy Excel 1. 引入依赖并给出示例 excel     2. 两种读取的方式         (1)确定表头:建立对象,和表头形成映射。(这里以此为例)         (2)不确定表头:每一行映射为 MapString, Object。 3. 先创建 excel 中表头对应

    2024年02月12日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包