POI有三种API:
POI-HSSFPOI-XSSFSXSSF
官方文档的说法:
HSSF是POI项目的Excel '97(-)文件格式的纯Java实现。XSSF是POI Project的Excel OOXML(.xlsx)文件格式的纯Java实现。
自3.8-beta3以来,POI提供了基于XSSF构建的低内存占用SXSSF API。
SXSSF是XSSF的API兼容流式扩展,用于在必须生成非常大的电子表格时使用,并且堆空间有限。SXSSF通过限制对滑动窗口内行的访问来实现其低内存占用,而XSSF允许访问文档中的所有行。不再在窗口中的旧行变得不可访问,因为它们被写入磁盘。
简单的说,HSSF对应旧的xls格式,XSSF对应新的xlsx格式,SXSSF是在XSSF的基础上,支持导出大批量的excel数据。
要使用POI,要知道以下关键代码:
//创建工作簿,对应整个xlsx文件XSSFWorkbook workbook = new XSSFWorkbook();//创建sheet,对应excel的单个sheetXSSFSheet sheet = workbook.createSheet("sheet1");//创建行,对应excel中的一行XSSFRow row = sheet.createRow(0)//创建单元格,对应row中的一格XSSFCell cell = row.createCell(0);//单元格设置值cell.setCellValue("cell");//单元格设置样式cell.setCellStyle(style);
其中style要从workbook中创建,简单的style示例:
XSSFCellStyle style = workbook.createCellStyle();//居中style.setAlignment(HorizontalAlignment.CENTER);style.setVerticalAlignment(VerticalAlignment.CENTER);//borderstyle.setBorderLeft(BorderStyle.THIN);style.setBorderTop(BorderStyle.THIN);style.setBorderRight(BorderStyle.THIN);style.setBorderBottom(BorderStyle.THIN);
将workbook保存到文件:
FileOutputStream file = new FileOutputStream("example.xlsx");workbook.write(file);file.close();
现在就导出成功了。
POI的maven依赖:
<dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>4.1.0</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>4.1.0</version></dependency>
version自行更换就好。
一个已经封装好的工具:/gaoice/easyexcel
方便快速导出excel。