java实现导入导出的开源工具之POI和EasyExcel

前言

我们经常需要将项目中的表格数据或者文档数据进行导入或者导出操作,这个如果自己从零开始做还比较麻烦。比如我之前就职的公司都是自己做的组件,但是很不好用,BUG 太多。关于表格导入导出,市面上比较知名的开源就是 Apache 的POI 和 阿里巴巴的 EasyExcel了。EasyExcel 也是对 POI 的改进和封装, 更加好用。下面通过一些 demo 学习如何使用这两个开源组件。这两个组件都不难,多看文档就能会,尤其是 EasyExcel 的文档非常详细。这篇博客主要自己在写 demo 的时候整理的笔记,方便以后使用的时候查阅。如果能帮到你那就更好了

日常开发需求

1、将用户的信息导出为 excel 表格。

2、将 Excel 表中的信息录入到网站数据库。

开发中经常会涉及到 excel 的 处理,如导出 Excel ,导入 Excel 到数据库中。

操作 Excel 目前比较流行的就是 Apache POI 和阿里巴巴的 EasyExcel。

Apache POI

Apache POI 官网: http://poi.apache.org/index.html

结构:

HSSF - 提供读写Microsoft Excel格式档案的功能。excel 2003 版本(块,但是不能读写超过65536行记录)

XSSF - 提供读写Microsoft Excel OOXML格式档案的功能。excel 207 版本(慢,但是能读写超过65536行记录)

SXSSF - 提供读写Microsoft Excel OOXML格式档案的功能。excel 207 版本(XSSF升级版,比XSSF快,能读写超过65536行记录)

HWPF - 提供读写Microsoft Word格式档案的功能。

HSLF - 提供读写Microsoft PowerPoint格式档案的功能。

HDGF - 提供读写Microsoft Visio格式档案的功能。

EasyExcel

GitHub 地址: https://github.com/alibaba/easyexcel

EasyExcel 官网: https://www.yuque.com/easyexcel/doc/easyexcel

EasyExcel 是阿里巴巴开源的一个 excel处理框架,以使用简单、节省内存著称。

EasyExcel 能大大减少内存占用的主要原因是在解析 Excel 时没有将文件数据一次性全部加载到内存中,而是从磁盘上一行行读取数据,逐个解析。

1、POI-Excel 写

1、建立一个空项目,创建普通的 Module 。

2、引入依赖:

<!--xls(03)-->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>4.1.2</version>
</dependency>
<!--xlsx(07)-->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>4.1.2</version>
</dependency>
<!--时间格式化工具-->
<dependency>
    <groupId>joda-time</groupId>
    <artifactId>joda-time</artifactId>
    <version>2.10.6</version>
</dependency>
<!--junit-->
<dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.13</version>
</dependency>

03 | 07 版本的写操作,就是对象不一样,方法都是一样的。

需要注意:2003 版本和 2007 版本存在兼容性问题, 03 版本最多只有 65535 行。

03 版本:

package com.godfrey;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.joda.time.DateTime;
import org.junit.Test;

import java.io.FileOutputStream;
import java.io.IOException;

/**

  • description : 测试类

  • @author godfrey

  • @since 2020-07-11
    */
    public class ExcelWriteTest {

    String PATH = “H:\code\java\StudyByKuang\poi-study\”;

    @Test
    public void testWrite03() throws IOException {
    //1.创建工作簿
    Workbook workbook = new HSSFWorkbook();
    //2.创建工作表
    Sheet sheet = workbook.createSheet(“godfrey日常统计表”);
    //3.创建一个行
    Row row1 = sheet.createRow(0);
    //4.创建一个单元格(1,1)
    Cell cell11 = row1.createCell(0);
    cell11.setCellValue(“今日的新增安排”);
    //(1,2)
    Cell cell12 = row1.createCell(1);
    cell12.setCellValue(666);

     <span class="hljs-comment">//第二行(2,1)</span>
     Row row2 = sheet.createRow(<span class="hljs-number">1</span>);
     Cell cell21 = row2.createCell(<span class="hljs-number">0</span>);
     cell21.setCellValue(<s
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值