# excel **Repository Path**: YeZhiyueGitee/excel ## Basic Information - **Project Name**: excel - **Description**: excel - **Primary Language**: Unknown - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-11-06 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README 国内最流行的Excel技术(POI、EasyExcel) @[TOC](文章目录) # 前言 Excel在非常多的业务场景中都有使用,作为一个程序员,掌握一门Excel操作技能可以说是不可或缺了。国内最常用的Excel技术可以说就是Apache的POI和阿里巴巴的EasyExcel了。下面就来看看这两门技术如何简单的入门。之后的工具封装就看大家各自的如何使用了。 --- # 环境搭建 ## 参考源码 *返回目录* --- # POI [Apache POI 官网:https://poi.apache.org/](https://poi.apache.org/) ## 依赖 *返回目录* ```java org.apache.poi poi 3.9 org.apache.poi poi-ooxml 3.9 joda-time joda-time 2.10.1 junit junit 4.12 ``` ## 常用类 *返回目录* **POI中有几个常用的类,下面就来看看** - HSSF - Excel.xls 2003 版本(有最大行数限制) - XSSF - Excel.xlsx OOXML 2007版本(无最大版本限制) - HWPF - Word 处理 - HSLF - PowerPoint 处理 - HDGF - Visio 处理 当然我们最常用的就是第一个和第二个,这两个是操作Excel的类,注意两者之间的版本是有区别的,还有文件后缀名称也是不同的。 ## 文件写出(简单) *返回目录* **基本逻辑:** - 创建一个工作簿 - 创建工作簿中的一张表 - 创建表中的一行 - 创建一行中的一个单元格 ```java public class PoiController { /** * HSSF - Excel.xls 2003 版本(有最大行数限制) * XSSF - Excel.xlsx OOXML 2007版本(无最大版本限制) * HWPF - Word 处理 * HSLF - PowerPoint 处理 * HDGF - Visio 处理 */ @Test public void writer() throws IOException { // 建工作簿 // 2003 版本 Workbook workbook = new HSSFWorkbook(); String excelType = "/poi.xls"; // 2007 版本 // Workbook workbook = new XSSFWorkbook(); // String excelType = "/poi.xlsx"; // 2007 版本 用于处理大量数据(会对数据进行缓存) // Workbook workbook = new SXSSFWorkbook(); // String excelType = "/poi.xlsx"; // 建表 Sheet sheet = workbook.createSheet("表一"); // 建立第一行 Row row1 = sheet.createRow(0); Cell cell00 = row1.createCell(0); cell00.setCellValue("单元格 100"); Cell cell01 = row1.createCell(1); cell01.setCellValue("单元格 101"); // 建立第二行 Row row2 = sheet.createRow(1); Cell cell10 = row2.createCell(0); cell10.setCellValue("单元格200"); Cell cell11 = row2.createCell(1); cell11.setCellValue("单元格201"); // 输出文件 String path = System.getProperty("user.dir"); FileOutputStream file = new FileOutputStream(path + excelType); workbook.write(file); file.close(); } } ``` ## 文件读取(简单) *返回目录* **基本逻辑:** - 通过流创建一个工作簿 - 读取工作簿中的一张表 - 读取表中的一行 - 读取一行中的一个单元格(需要进行特殊处理,下面会进行演示) ```java public class PoiController { /** * 需要注意Excel中的数据格式是多样的,需要自己进行处理 */ @Test public void reader() throws IOException { String excelType = "/poi.xls"; String path = System.getProperty("user.dir"); FileInputStream file = new FileInputStream(path + excelType); // 2003 版本 Workbook workbook = new HSSFWorkbook(file); // 2007 版本 // Workbook workbook = new XSSFWorkbook(file); // String excelType = "/poi.xlsx"; // 2007 版本 用于处理大量数据(会对数据进行缓存) // Workbook workbook = new SXSSFWorkbook(file); // String excelType = "/poi.xlsx"; // 获取表格 Sheet sheet1 = workbook.getSheetAt(0); // 获取行 Row row1 = sheet1.getRow(0); // 获取单元格 Cell cell00 = row1.getCell(0); Cell cell01 = row1.getCell(1); // 输出内容 System.out.println(cell00.getStringCellValue()); System.out.println(cell01.getStringCellValue()); file.close(); } } ``` ## 文件读取(进阶) *返回目录* ```java public class PoiController { /** * HSSF - Excel.xls 2003 版本(有最大行数限制) * XSSF - Excel.xlsx OOXML 2007版本(无最大版本限制) * HWPF - Word 处理 * HSLF - PowerPoint 处理 * HDGF - Visio 处理 */ @Test public void writer() throws IOException { // 建工作簿 // 2003 版本 Workbook workbook = new HSSFWorkbook(); String excelType = "/poi.xls"; // 2007 版本 // Workbook workbook = new XSSFWorkbook(); // String excelType = "/poi.xlsx"; // 2007 版本 用于处理大量数据(会对数据进行缓存) // Workbook workbook = new SXSSFWorkbook(); // String excelType = "/poi.xlsx"; // 建表 Sheet sheet = workbook.createSheet("表一"); // 建立第一行 Row row1 = sheet.createRow(0); Cell cell00 = row1.createCell(0); cell00.setCellValue("单元格 100"); Cell cell01 = row1.createCell(1); cell01.setCellValue("单元格 101"); // 建立第二行 Row row2 = sheet.createRow(1); Cell cell10 = row2.createCell(0); cell10.setCellValue("单元格200"); Cell cell11 = row2.createCell(1); cell11.setCellValue("单元格201"); // 输出文件 String path = System.getProperty("user.dir"); FileOutputStream file = new FileOutputStream(path + excelType); workbook.write(file); file.close(); } } ``` ## *返回目录* --- # MyExcel [easyExcel 官网地址:https://github.com/alibaba/easyexcel](https://github.com/alibaba/easyexcel) ## 基本介绍(优势) *返回目录* **优势:**以使用简单、节省内存著称。 **Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及解压后存储都是在内存中完成的,内存消耗依然很大。easyexcel重写了poi对07版Excel的解析,能够原本一个3M的excel用POI sax依然需要100M左右内存降低到几M,并且再大的excel不会出现内存溢出,03版依赖POI的sax模式。在上层做了模型转换的封装,让使用者更加简单方便** ## 简单写 这里就是参考官方文档的,其他操作参考文档即可,里面写的更加清楚。 [https://www.yuque.com/easyexcel/doc/write](https://www.yuque.com/easyexcel/doc/write) ```java @Data public class DemoData { @ExcelProperty("字符串标题") private String string; @ExcelProperty("日期标题") private Date date; @ExcelProperty("数字标题") private Double doubleData; /** * 忽略这个字段 */ @ExcelIgnore private String ignore; } ``` ```java private List data() { List list = new ArrayList(); for (int i = 0; i < 10; i++) { DemoData data = new DemoData(); data.setString("字符串" + i); data.setDate(new Date()); data.setDoubleData(0.56); list.add(data); } return list; } /** * 最简单的写 *

1. 创建excel对应的实体对象 参照{@link DemoData} *

2. 直接写即可 */ @Test public void simpleWrite() { // 写法1 String fileName = TestFileUtil.getPath() + "simpleWrite" + System.currentTimeMillis() + ".xlsx"; // 这里 需要指定写用哪个class去写,然后写到第一个sheet,名字为模板 然后文件流会自动关闭 // 如果这里想使用03 则 传入excelType参数即可 EasyExcel.write(fileName, DemoData.class).sheet("模板").doWrite(data()); // 写法2 fileName = TestFileUtil.getPath() + "simpleWrite" + System.currentTimeMillis() + ".xlsx"; // 这里 需要指定写用哪个class去写 ExcelWriter excelWriter = null; try { excelWriter = EasyExcel.write(fileName, DemoData.class).build(); WriteSheet writeSheet = EasyExcel.writerSheet("模板").build(); excelWriter.write(data(), writeSheet); } finally { // 千万别忘记finish 会帮忙关闭流 if (excelWriter != null) { excelWriter.finish(); } } } ``` *返回目录* ## 简单读 *返回目录* 参考文档吧,里面详细 [https://www.yuque.com/easyexcel/doc/read](https://www.yuque.com/easyexcel/doc/read) --- # 小结 - POI的操作比较复杂,适合满足高级操作,如果操作非常细致,那么就用POI吧 - EasyExcel比较简单,如果简单操作Excel,那么就用EasyExcel吧 这里推荐一款更加简单的Excel操作技术,使用起来非常简单,下面是地址: [MyExcel 官网文档:](https://github.com/liaochong/myexcel/wiki/Excel%E9%BB%98%E8%AE%A4%E5%AF%BC%E5%87%BA)