在Java开发中,我们经常需要实现Excel数据的读取和导入功能。对于Excel文件,常用的Java处理库有Apache POI和jxl等。其中,Apache POI提供了一个非常完整的解决方案,可以处理老旧的Excel 2003格式,也可以处理较新的Excel 2007以来的格式。本文将以Apache POI为例,从环境搭建、文件读取到数据解析,详细说明如何用Java导入Excel文件。
一、环境搭建
首先,我们需要在项目中引入Apache POI的相关依赖。在Maven项目中,我们可以在pom.xml文件中添加以下依赖:
<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实例。
InputStream inp = new FileInputStream("workbook.xlsx"); Workbook wb = WorkbookFactory.create(inp);
Workbook是用来表示Excel文件的一个对象。每个Workbook可以包含多个Sheet,每个Sheet又可以包含多个Row,每个Row可以包含多个Cell。
三、解析Excel数据
当我们获得了Workbook后,我们就可以对其进行解析,拿到我们需要的数据。假设我们知道数据位于第一个Sheet,第二行第三列,我们可以用以下方式读取:
Sheet sheet = wb.getSheetAt(0); Row row = sheet.getRow(1); Cell cell = row.getCell(2);
需要注意的是,Sheet、Row和Cell的索引都是从0开始的,所以上述代码中的getRow(1)和getCell(2)分别表示获取第二行和第三列。
当我们得到了Cell,我们就可以根据它的类型,用不同的方式读取它的值。例如:
if(cell.getCellType()==CellType.STRING) { String value = cell.getStringCellValue(); } else if(cell.getCellType()==CellType.NUMERIC) { double value = cell.getNumericCellValue(); }
对于日期类型的数据,我们还需要用DateUtil来进行处理。例如:
if(DateUtil.isCellDateFormatted(cell)) { Date value = cell.getDateCellValue(); }
在处理完Excel数据后,我们也需要关闭输入流以释放资源:
inp.close();
至此,我们已经完成了用Java导入Excel文件的整个过程。
原创文章,作者:BZHJ,如若转载,请注明出处:https://www.beidandianzhu.com/g/1370.html