基于Java8实现提高Excel读写效率

2023-12-10java编程
175

基于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>

其中,poipoi-ooxml分别对应于操作.xls.xlsx格式的Excel文件的依赖。

2. 读取Excel

读取Excel主要涉及到三个类,分别是WorkbookSheetRow

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也是涉及到WorkbookSheetRow的操作。

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的方法,提高工作效率。

The End

相关推荐

一文带你掌握Java8中Lambda表达式 函数式接口及方法构造器数组的引用
Lambda表达式是Java 8中引入的新特性之一,它是一个匿名函数,可以捕获参数并表现为一个代码块,而不像方法一样需要一个固定的名称。它主要用于传递行为或代码块以及事件处理等操作。...
2023-12-11 java编程
30

基于Java 谈回调函数
下面为您详细讲解基于Java的回调函数。...
2023-12-11 java编程
21

java equals函数用法详解
在Java中,equals()是用来比较两个对象是否相等的函数。equals()方法是Object类中的方法,因此所有Java类都包含equals()方法。在默认情况下,equals()方法比较对象的引用地址是否相同,即两个对象是否是同一个实例。但是,我们可以覆盖equals()方法,来定义自...
2023-12-11 java编程
63

JavaWeb学习笔记分享(必看篇)
JavaWeb是Java在Web领域的应用,是目前非常热门的技术之一。但是JavaWeb涉及到的技术非常广泛,初学者很容易迷失方向。本文总结了JavaWeb的基础知识,为初学者提供了一份学习笔记分享,希望能够帮助大家快速入门。...
2023-12-11 java编程
8

Java中replace、replaceAll和replaceFirst函数的用法小结
在Java编程中,字符串操作是很常见的,而替换字符串是其中常用的操作之一。Java提供了三种函数用于替换字符串:replace、replaceAll和replaceFirst。这篇文章将为您详细介绍它们的用法。...
2023-12-11 java编程
121

基于Java中进制的转换函数详解
进制是数学中一种表示数值大小的方法,常见的进制有10进制、2进制、16进制等。...
2023-12-11 java编程
45