Java导入Excel文件的实现方式

2023-09-21 08:27:17 浏览数 (1)

在Java开发中,我们经常需要实现Excel数据的读取和导入功能。对于Excel文件,常用的Java处理库有Apache POI和jxl等。其中,Apache POI提供了一个非常完整的解决方案,可以处理老旧的Excel 2003格式,也可以处理较新的Excel 2007以来的格式。本文将以Apache POI为例,从环境搭建、文件读取到数据解析,详细说明如何用Java导入Excel文件。

一、环境搭建

首先,我们需要在项目中引入Apache POI的相关依赖。在Maven项目中,我们可以在pom.xml文件中添加以下依赖:

代码语言:javascript复制
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>4.1.2</version>
</dependency>

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>4.1.2</version>
</dependency>

当然,如果是非Maven项目,我们也可以通过其他方式引入Apache POI库。

二、读取Excel文件

当环境搭建好后,我们需要将Excel文件读取到Java程序中。首先,我们需要创建一个InputStream实例,然后通过WorkbookFactory的create方法创建Workbook实例。

代码语言:javascript复制
InputStream inp = new FileInputStream("workbook.xlsx");
Workbook wb = WorkbookFactory.create(inp);

Workbook是用来表示Excel文件的一个对象。每个Workbook可以包含多个Sheet,每个Sheet又可以包含多个Row,每个Row可以包含多个Cell。

三、解析Excel数据

当我们获得了Workbook后,我们就可以对其进行解析,拿到我们需要的数据。假设我们知道数据位于第一个Sheet,第二行第三列,我们可以用以下方式读取:

代码语言:javascript复制
Sheet sheet = wb.getSheetAt(0);
Row row = sheet.getRow(1);
Cell cell = row.getCell(2);

需要注意的是,Sheet、Row和Cell的索引都是从0开始的,所以上述代码中的getRow(1)和getCell(2)分别表示获取第二行和第三列。

当我们得到了Cell,我们就可以根据它的类型,用不同的方式读取它的值。例如:

代码语言:javascript复制
if(cell.getCellType()==CellType.STRING) {
    String value = cell.getStringCellValue();
} else if(cell.getCellType()==CellType.NUMERIC) {
    double value = cell.getNumericCellValue();   
}

对于日期类型的数据,我们还需要用DateUtil来进行处理。例如:

代码语言:javascript复制
if(DateUtil.isCellDateFormatted(cell)) {
    Date value = cell.getDateCellValue();
}

在处理完Excel数据后,我们也需要关闭输入流以释放资源:

代码语言:javascript复制
inp.close();

至此,我们已经完成了用Java导入Excel文件的整个过程。

0 人点赞