POI(Poor Obfuscation Implementation)是一个开源的Java库,主要用于处理Microsoft Office格式文件,如Excel、Word和PowerPoint等。以下将详细介绍POI在Excel文件导入导出方面的应用。
一、POI简介
POI提供了丰富的API来创建、修改和显示MS Office文件。对于Excel文件,它支持旧版的XLS格式(HSSF)和新版的XLSX格式(XSSF)。此外,还有SXSSF用于处理大型Excel文件,以减少内存占用。
二、导入Excel文件
- 读取文件:首先,使用
FileInputStream
或InputStream
来读取Excel文件。 - 创建Workbook:根据文件类型(XLS或XLSX),使用
HSSFWorkbook
或XSSFWorkbook
来创建Workbook对象。 - 遍历Sheet:通过Workbook对象获取Sheet的集合,然后遍历每个Sheet。
- 读取数据:在Sheet中,通过行(Row)和单元格(Cell)来读取数据。单元格可能包含文本、数字、日期等多种类型的数据,需要相应地处理。
三、导出Excel文件
- 创建Workbook:根据需要导出的文件格式(XLS或XLSX),使用
HSSFWorkbook
或XSSFWorkbook
创建Workbook对象。 - 创建Sheet:在Workbook中创建一个或多个Sheet,用于存放数据。
- 写入数据:在Sheet中,通过创建行(Row)和单元格(Cell),并设置单元格的值来写入数据。可以设置单元格的样式、字体、大小等属性。
- 输出文件:最后,使用
FileOutputStream
将Workbook对象写入到文件中。
四、示例代码
导出
import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import java.io.FileOutputStream; import java.io.IOException; public class ExcelExportExample { public static void main(String[] args) { // 创建Workbook对象 Workbook workbook = new XSSFWorkbook(); // 创建Sheet对象 Sheet sheet = workbook.createSheet("Example Sheet"); // 创建行(Row) Row row = sheet.createRow(0); // 创建单元格(Cell)并写入数据 Cell cell = row.createCell(0); cell.setCellValue("Hello POI!"); // 设置单元格样式(可选) CellStyle cellStyle = workbook.createCellStyle(); cellStyle.setAlignment(HorizontalAlignment.CENTER); cell.setCellStyle(cellStyle); // 输出文件 try (FileOutputStream outputStream = new FileOutputStream("example.xlsx")) { workbook.write(outputStream); } catch (IOException e) { e.printStackTrace(); } finally { try { workbook.close(); } catch (IOException e) { e.printStackTrace(); } } } }