从 Java 程序中读取 Excel 数据347



Excel 是存储和处理电子表格数据的流行工具。在 Java 程序中读取 Excel 数据对于处理来自电子表格的数据处理任务非常有用。本文将指导您使用 Apache POI 库从 Java 程序中读取 Excel 数据。

Apache POI 库

Apache POI 是一个开源 Java 库,用于操作 Microsoft Office 格式的文件,包括 Excel。它提供了各种类和方法来读取、写入和修改 Excel 工作簿和工作表。

读取 Excel 工作簿

要从 Java 程序中读取 Excel 工作簿,请按照以下步骤操作:1. 导入 Apache POI 库:在您的 Java 项目中导入以下依赖项:
```xml


poi
5.2.2

```
2. 创建 FileInputStream:使用 `FileInputStream` 类创建一个输入流,指向要读取的 Excel 文件:
```java
InputStream fis = new FileInputStream("");
```
3. 创建 XSSFWorkbook:使用 `XSSFWorkbook` 类创建 Excel 工作簿对象:
```java
XSSFWorkbook workbook = new XSSFWorkbook(fis);
```
4. 关闭 FileInputStream:读取 Excel 文件后,关闭 `FileInputStream`:
```java
();
```

读取 Excel 工作表

要从 Excel 工作簿中读取工作表,请按照以下步骤操作:1. 获取工作表:使用 `XSSFWorkbook` 对象的 `getSheetAt(int index)` 方法获取要读取的工作表:
```java
XSSFSheet worksheet = (0);
```
2. 读取数据:使用 `XSSFRow` 和 `XSSFCell` 类逐行和逐单元格地读取数据:
```java
for (int i = 0; i < (); i++) {
XSSFRow row = (i);
for (int j = 0; j < (); j++) {
XSSFCell cell = (j);
(());
}
}
```

处理单元格数据

读取单元格数据后,您需要根据单元格类型处理数据。Apache POI 提供了用于获取单元格类型和值的方法,例如:* 获取单元格类型:使用 `XSSFCell` 对象的 `getCellType()` 方法获取单元格类型,它可以是字符串、数字、日期等。
* 获取字符串值:对于字符串单元格,使用 `getStringCellValue()` 方法获取字符串值。
* 获取数字值:对于数字单元格,使用 `getNumericCellValue()` 方法获取数字值。
* 获取日期值:对于日期单元格,使用 `getDateCellValue()` 方法获取日期值。

示例代码

以下是一段完整的示例代码,演示如何从 Java 程序中读取 Excel 数据:```java
import ;
import ;
import ;
import ;
import ;
public class ReadExcelData {
public static void main(String[] args) {
try {
// Create a FileInputStream for the Excel file
FileInputStream fis = new FileInputStream("");
// Create an XSSFWorkbook object
XSSFWorkbook workbook = new XSSFWorkbook(fis);
// Get the first worksheet in the workbook
XSSFSheet worksheet = (0);
// Iterate over the rows and cells in the worksheet
for (int i = 0; i < (); i++) {
XSSFRow row = (i);
for (int j = 0; j < (); j++) {
XSSFCell cell = (j);
// Get the cell type and print the value
switch (()) {
case STRING:
(());
break;
case NUMERIC:
(());
break;
case DATE:
(());
break;
default:
("Unknown cell type");
}
}
}
// Close the FileInputStream
();
} catch (Exception e) {
();
}
}
}
```

2024-10-29


上一篇:Java 静态方法详解

下一篇:Java 静态方法调用非静态方法: 剖析和示例