在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文件的整个过程。