###在Java中,HSSFWorkbook、XSSFWorkbook和SXSSFWorkbook都是Apache POI库中用于处理Excel文件的类。它们之间的主要区别如下:
HSSFWorkbook:它是POI库中处理旧版Excel(.xls)文件的类。HSSFWorkbook基于OLE2 Compound Document Format,适用于Excel 97-2003版本。它使用的是基于二进制格式的文件结构。HSSFWorkbook的缺点是对大量数据的处理效率相对较低。
XSSFWorkbook:它是POI库中处理新版Excel(.xlsx)文件的类。XSSFWorkbook基于Office Open XML格式,适用于Excel 2007及更高版本。它使用的是基于XML的文件结构。相比HSSFWorkbook,XSSFWorkbook支持更多的Excel特性,并且在处理大量数据时有更好的性能。
SXSSFWorkbook:它是POI库中处理大型Excel文件的类。SXSSFWorkbook是一种流式操作的工作簿,可用于处理超出内存限制的大型数据集。SXSSFWorkbook将数据写入临时文件而不是完全加载到内存中,因此可以处理非常大的Excel文件而不会导致内存溢出。这对于需要处理数百万行数据或占用大量内存的情况非常有用。
#####总结:HSSFWorkbook适用于旧版Excel文件(.xls),XSSFWorkbook适用于新版Excel文件(.xlsx),而SXSSFWorkbook适用于处理大型Excel文件,特别是涉及大量数据的情况。选择适合您需求的POI工作簿类可以提高性能和功能的使用体验。
###1. 导包:
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.0.1</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.0.1</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml-schemas</artifactId>
<version>4.0.1</version>
</dependency>
###2. 代码块
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
XSSFWorkbook workbook = null;
try {
workbook = new XSSFWorkbook(new File("D:\\templateExcel\\test.xlsx"));
//获取excel下的所有sheet页
int numberSheets = workbook.getNumberOfSheets();
System.out.println("sheet总页数:" + numberSheets);
int i = 0;
while (i < numberSheets){
System.out.println("读取第" + (i+1) + "个sheet页");
XSSFSheet sheetAt = workbook.getSheetAt(i);
//获取最后一行,总行数
int lastRowNum = sheetAt.getLastRowNum();
if (lastRowNum == 0){
System.out.println("sheet页"+(i+1)+"无数据!");
continue;
}
//循环每一行 此处从0开始
for(int h = 0; h <= lastRowNum; h++){
//获取行数据
XSSFRow row = sheetAt.getRow(h);
System.out.println("一行中单元格数" + row.getLastCellNum());
//循环每一行的格子 即总单元格数 ***注意:此处从1开始计数***
for (int g = 0; g < row.getLastCellNum(); g++){
System.out.println("第"+ (h+1) +"行,第"+ (g+1) +"列数据:" + row.getCell(g));
}
}
i++;
}
workbook.close();
} catch (Exception e) {
e.printStackTrace();
}