Java利用POI读取Excel示例与解析
需积分: 10 140 浏览量
更新于2024-09-11
收藏 42KB DOC 举报
"这篇文档是关于使用Apache POI库在Java中读取Excel文件的示例程序。通过导入相应的jar包并使用特定的API,开发者可以实现对Excel文档的读取操作,对进行Excel开发的人员具有指导意义。"
Apache POI是一个流行的开源Java API,它允许开发人员创建、修改和显示Microsoft Office格式的文件,其中包括Excel。在这个例子中,我们将重点放在如何使用POI来读取Excel文件。
首先,确保在项目中引入了`poi-3.1-FINAL.jar`库。接着,在Java代码中,我们需要引入相关的包,例如`java.io`用于处理输入输出,以及`org.apache.poi`包,它是POI库的一部分,包含处理Excel文件所需的类。
以下是一个简单的读取Excel文件的Java程序:
```java
package demo.excel;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import org.apache.poi.hssf.eventusermodel.HSSFRequest;
import org.apache.poi.hssf.model.Sheet;
import org.apache.poi.hssf.model.Workbook;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
public class ExcelDemo {
public static void main(String[] args) {
File f = new File("f:/aa.xls");
if (f.exists()) {
try {
InputStream fis = new FileInputStream(f);
// 创建POIFSFileSystem对象,用于读取Excel文件
POIFSFileSystem poifs = new POIFSFileSystem(fis);
// 创建HSSFWorkbook对象,表示整个Excel工作簿
HSSFWorkbook wb = new HSSFWorkbook(poifs);
List<List<String>> retList = new ArrayList<>();
System.out.println("此文件中表的数量是:" + wb.getNumberOfSheets());
// 遍历每个工作表
for (int sheetIndex = 0; sheetIndex < wb.getNumberOfSheets(); sheetIndex++) {
HSSFSheet sheet = wb.getSheetAt(sheetIndex);
System.out.println("当前工作表名称:" + sheet.getSheetName());
// 遍历每行数据
for (int rowIndex = 0; ; rowIndex++) { // 注意:终止条件通常为HSSFRow.getLastRowNum()+1
HSSFRow row = sheet.getRow(rowIndex);
if (row == null) break; // 如果行为空,跳出循环
List<String> rowData = new ArrayList<>();
// 遍历单元格数据
for (int cellIndex = 0; cellIndex < row.getLastCellNum(); cellIndex++) {
HSSFCell cell = row.getCell(cellIndex);
if (cell != null) {
String cellValue = getCellValue(cell);
rowData.add(cellValue);
}
}
retList.add(rowData);
}
}
// 关闭工作簿和输入流
wb.close();
fis.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
} else {
System.out.println("文件不存在!");
}
}
// 获取单元格的值
private static String getCellValue(HSSFCell cell) {
switch (cell.getCellType()) {
case STRING:
return cell.getStringCellValue();
case NUMERIC:
return String.valueOf(cell.getNumericCellValue());
// 处理其他类型的单元格值
// ...
}
return "";
}
}
```
在这个程序中,我们首先创建`POIFSFileSystem`对象来打开Excel文件,然后通过它创建`HSSFWorkbook`对象,该对象代表整个Excel工作簿。我们可以通过`getNumberOfSheets()`方法获取工作簿中的工作表数量,并使用`getSheetAt(int index)`来访问特定索引的工作表。
在遍历工作表的过程中,我们读取每一行(`HSSFRow`)和每个单元格(`HSSFCell`)。`HSSFRow.getLastCellNum()`返回行中最后一个非空白单元格的索引,`HSSFCell.getCellType()`确定单元格的类型(如字符串、数字等),并根据类型提取对应的值。
读取完成后,记得关闭工作簿和输入流以释放资源。这个例子中,读取到的数据被存储在一个二维列表中,方便后续处理。
Apache POI提供了一套丰富的API,使得Java开发者能够方便地处理Excel文件,包括读取、写入和修改数据,以及创建新的Excel文件。通过理解和应用这些API,你可以构建自己的Excel处理工具或集成到现有的业务系统中。
2022-11-14 上传
2021-09-13 上传
2520 浏览量
点击了解资源详情
286 浏览量
118 浏览量
241 浏览量
295 浏览量
点击了解资源详情
hq8215
- 粉丝: 0
- 资源: 3
最新资源
- Risk Assessment Guidebook for e-Commerce/e-Government
- GDB调式ARM开发板
- Exchange Server 2007快速部署指南
- 工业电器现行国标大全
- LoadRunner使用手册.pdf
- 模拟系统使用说明.doc
- Hibernate开发指南
- 深入Spring 2:轻量级J2EE开发框架原理与实践 .pdf
- 使用TEFS(TM)平台构建应用系统
- bht8000开发手册
- Oracle数据库维护.pdf
- Oracle的入门心得.pdf
- Apache 2.2 中文手册.pdf
- java swing架构--中英文对照版
- REALBASIC开发指南
- arcgis server详细安装部署文档