基于Java8实现提高Excel读写效率
1. 导入依赖
我们可以使用Apache POI库来读写Excel,那么我们先来看一下如何在Java中导入Apache POI库的依赖。
<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>
其中,poi
和poi-ooxml
分别对应于操作.xls
和.xlsx
格式的Excel文件的依赖。
2. 读取Excel
读取Excel主要涉及到三个类,分别是Workbook
、Sheet
和Row
。
try (Workbook workbook = WorkbookFactory.create(inputStream)) {
Sheet sheet = workbook.getSheetAt(0);
Iterator<Row> rowIterator = sheet.rowIterator();
while (rowIterator.hasNext()) {
Row row = rowIterator.next();
Iterator<Cell> cellIterator = row.cellIterator();
while (cellIterator.hasNext()) {
Cell cell = cellIterator.next();
System.out.print(cell.toString() + "\t");
}
System.out.println();
}
}
以上代码演示了如何读取Excel中的所有行和列,并输出到控制台。
3. 写入Excel
写入Excel也是涉及到Workbook
、Sheet
和Row
的操作。
try (Workbook workbook = new XSSFWorkbook()) {
Sheet sheet = workbook.createSheet("Sheet1");
Row row = sheet.createRow(0);
Cell cell = row.createCell(0);
cell.setCellValue("Hello World");
try (FileOutputStream outputStream = new FileOutputStream(outputFile)) {
workbook.write(outputStream);
}
}
以上代码演示了如何在内存中新建一个Excel文件,并写入一行数据。写入完成后,数据会保存到指定的输出流中。
4. 利用Java8 Stream提高效率
Java8引入的Stream API可以非常方便地对集合数据进行筛选、转换等操作。可以利用Stream API对Excel中的数据进行快速筛选等操作。
try (Workbook workbook = WorkbookFactory.create(inputStream)) {
Sheet sheet = workbook.getSheetAt(0);
IntStream.range(0, sheet.getLastRowNum() + 1)
.mapToObj(sheet::getRow)
.peek(row -> System.out.print(row.getCell(0).toString() + "\t"))
.forEach(row -> System.out.print(row.getCell(1).toString() + "\t"));
}
以上代码利用Stream API快速遍历Excel中的每一行数据,并筛选输出第一列和第二列的数据。
5. 示例说明1:批量修改Excel中的数据
假设我们有一个Excel文件,其中有一列存储着产品价格,现在我们要对所有产品的价格进行批量修改。
try (Workbook workbook = WorkbookFactory.create(inputStream)) {
Sheet sheet = workbook.getSheetAt(0);
IntStream.range(0, sheet.getLastRowNum() + 1)
.mapToObj(sheet::getRow)
.forEach(row -> {
Cell priceCell = row.getCell(2);
double price = priceCell.getNumericCellValue();
priceCell.setCellValue(price * 1.1);
});
try (FileOutputStream outputStream = new FileOutputStream(outputFile)) {
workbook.write(outputStream);
}
}
以上代码利用Stream API遍历每一行数据,将第三列的价格数据乘以1.1后重新写入Excel文件中。
6. 示例说明2:读取Excel中的特定数据
假设我们有一个Excel文件,其中有一列存储着产品名称,现在我们要找到所有名称为“Apple”的产品,并输出它们的价格。
try (Workbook workbook = WorkbookFactory.create(inputStream)) {
Sheet sheet = workbook.getSheetAt(0);
List<Row> rows = IntStream.range(0, sheet.getLastRowNum() + 1)
.mapToObj(sheet::getRow)
.filter(row -> row.getCell(0).toString().equals("Apple"))
.collect(Collectors.toList());
for (Row row : rows) {
Cell priceCell = row.getCell(1);
System.out.println(priceCell.getNumericCellValue());
}
}
以上代码利用Stream API快速遍历每一行数据,找到名称为“Apple”的行,并输出它们的价格数据。
7. 总结
本文详细讲解了如何使用Apache POI库读写Excel文件,并用Java8 Stream API提高读写效率。通过实际示例的演示,可以快速掌握使用Java8读写Excel的方法,提高工作效率。
本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!