<legend id='QRXkM'><style id='QRXkM'><dir id='QRXkM'><q id='QRXkM'></q></dir></style></legend>
      <i id='QRXkM'><tr id='QRXkM'><dt id='QRXkM'><q id='QRXkM'><span id='QRXkM'><b id='QRXkM'><form id='QRXkM'><ins id='QRXkM'></ins><ul id='QRXkM'></ul><sub id='QRXkM'></sub></form><legend id='QRXkM'></legend><bdo id='QRXkM'><pre id='QRXkM'><center id='QRXkM'></center></pre></bdo></b><th id='QRXkM'></th></span></q></dt></tr></i><div id='QRXkM'><tfoot id='QRXkM'></tfoot><dl id='QRXkM'><fieldset id='QRXkM'></fieldset></dl></div>

      <small id='QRXkM'></small><noframes id='QRXkM'>

      1. <tfoot id='QRXkM'></tfoot>

          <bdo id='QRXkM'></bdo><ul id='QRXkM'></ul>

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

        时间:2023-12-10

          • <i id='Zr5A3'><tr id='Zr5A3'><dt id='Zr5A3'><q id='Zr5A3'><span id='Zr5A3'><b id='Zr5A3'><form id='Zr5A3'><ins id='Zr5A3'></ins><ul id='Zr5A3'></ul><sub id='Zr5A3'></sub></form><legend id='Zr5A3'></legend><bdo id='Zr5A3'><pre id='Zr5A3'><center id='Zr5A3'></center></pre></bdo></b><th id='Zr5A3'></th></span></q></dt></tr></i><div id='Zr5A3'><tfoot id='Zr5A3'></tfoot><dl id='Zr5A3'><fieldset id='Zr5A3'></fieldset></dl></div>

            <small id='Zr5A3'></small><noframes id='Zr5A3'>

                <tbody id='Zr5A3'></tbody>
              <legend id='Zr5A3'><style id='Zr5A3'><dir id='Zr5A3'><q id='Zr5A3'></q></dir></style></legend><tfoot id='Zr5A3'></tfoot>
              • <bdo id='Zr5A3'></bdo><ul id='Zr5A3'></ul>

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

                  上一篇:java中rss解析器(rome.jar和jdom.jar)示例 下一篇:一个低学历者的辛酸程序路[贵在坚持]

                  相关文章

                    <bdo id='V3lCA'></bdo><ul id='V3lCA'></ul>

                2. <tfoot id='V3lCA'></tfoot>

                    <legend id='V3lCA'><style id='V3lCA'><dir id='V3lCA'><q id='V3lCA'></q></dir></style></legend>
                    <i id='V3lCA'><tr id='V3lCA'><dt id='V3lCA'><q id='V3lCA'><span id='V3lCA'><b id='V3lCA'><form id='V3lCA'><ins id='V3lCA'></ins><ul id='V3lCA'></ul><sub id='V3lCA'></sub></form><legend id='V3lCA'></legend><bdo id='V3lCA'><pre id='V3lCA'><center id='V3lCA'></center></pre></bdo></b><th id='V3lCA'></th></span></q></dt></tr></i><div id='V3lCA'><tfoot id='V3lCA'></tfoot><dl id='V3lCA'><fieldset id='V3lCA'></fieldset></dl></div>

                    <small id='V3lCA'></small><noframes id='V3lCA'>