Java获取excel中某一列优化实例
时间: 2024-05-14 09:15:18 浏览: 93
假设我们要从一个excel文件中获取第二列数据,以下是一个优化的示例代码:
```java
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;
public class ExcelReader {
public static void main(String[] args) throws Exception {
String excelFilePath = "path/to/excel.xlsx";
int columnNumber = 1; // 第二列的列号是1
List<String> columnValues = getColumnValues(excelFilePath, columnNumber);
// 打印出第二列的数据
for (String value : columnValues) {
System.out.println(value);
}
}
public static List<String> getColumnValues(String excelFilePath, int columnNumber) throws Exception {
List<String> columnValues = new ArrayList<>();
InputStream inputStream = new FileInputStream(excelFilePath);
Workbook workbook = WorkbookFactory.create(inputStream);
Sheet sheet = workbook.getSheetAt(0); // 获取第一个工作表
for (Row row : sheet) {
Cell cell = row.getCell(columnNumber);
if (cell != null) {
String value = cell.toString();
columnValues.add(value);
}
}
workbook.close();
inputStream.close();
return columnValues;
}
}
```
上面的示例代码中,我们使用了Apache POI库来读取excel文件。在`getColumnValues()`方法中,我们首先创建了一个空的List对象`columnValues`,然后打开excel文件并获取第一个工作表。接下来,我们使用一个for循环遍历工作表中的每一行,然后获取指定列号的单元格数据,并将其添加到`columnValues`列表中。最后,我们关闭了excel工作簿和输入流,并返回了`columnValues`列表。
由于我们在`getColumnValues()`方法中使用了Apache POI库的低级API,因此在处理大型excel文件时,该方法可能会比使用高级API的方法更快。
阅读全文