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是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。
结构:
HSSF - 提供读写[Microsoft Excel](https://baike.baidu.com/item/Microsoft Excel)格式档案的功能。excel 2003 版本
XSSF - 提供读写Microsoft Excel OOXML格式档案的功能。excel 207 版本
HWPF - 提供读写[Microsoft Word](https://baike.baidu.com/item/Microsoft Word)格式档案的功能。
HSLF - 提供读写Microsoft PowerPoint格式档案的功能。
HDGF - 提供读写[Microsoft Visio](https://baike.baidu.com/item/Microsoft Visio)格式档案的功能。
EasyExcel
EasyExcel 是阿里巴巴开源的一个 excel处理框架,以使用简单、节省内存著称。
EasyExcel 能大大减少内存占用的主要原因是在解析 Excel 时没有将文件数据一次性全部加载到内存中,而是从磁盘上一行行读取数据,逐个解析。
下面是 EasyExcel 和 POI 在解析Excel 时的对比图。
[图片上传失败...(image-4732b1-1587700594308)]
1、POI-Excel 写
创建项目
1、建立一个空项目,创建普通的 Module 。
2、引入依赖:
org.apache.poi
poi
3.9
org.apache.poi
poi-ooxml
3.9
joda-time
joda-time
2.10.1
junit
junit
4.12
03 | 07 版本的写操作,就是对象不一样,方法都是一样的。
需要注意:2003 版本和 2007 版本存在兼容性问题, 03 版本最多只有 65535 行。
03 版本:
package cn.itzhouq;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.joda.time.DateTime;
import org.junit.Test;
import java.io.FileOutputStream;
public class ExcelWriteTest {
String PATH = "F:\\workspaces\\workspaces_idea\\POIAndEasyExcel\\itzhouq-poi";
@Test
public void testWrite03 () throws Exception {
// 1. 创建一个工作薄
HSSFWorkbook workbook = new HSSFWorkbook();
// 2. 创建一个工作表
HSSFSheet sheet = workbook.createSheet("人员统计表");
// 3. 创建一个行 (1, 1)
Row row1 = sheet.createRow(0);
// 4. 创建一个单元格
Cell cell11 = row1.createCell(0);
cell11.setCellValue("今日新增人员");
Cell cell12 = row1.createCell(1);
cell12.setCellValue(666);
// 第二行
Row row2 = sheet.createRow(1);
Cell cell21 = row2.createCell(0); // (2,1 )
cell21.setCellValue("统计时间");
Cell cell22 = row2.createCell(1);
String time = new DateTime().toString("yyyy-MM-dd HH:mm:ss");