iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > JAVA >如何使用 Java 灵活读取 Excel 内容?
  • 829
分享到

如何使用 Java 灵活读取 Excel 内容?

javaexcel开发语言 2023-09-12 08:09:38 829人浏览 八月长安
摘要

在日常工作和学习中,我们经常需要从 excel 文件中读取数据。对于少量数据,手动复制和粘贴可能是可行的,但是对于大量的数据,这种方法会变得非常低效。在这种情况下,使用 Java 程序自动读取 Excel 文件中的数据将是更好的选择。 本教

在日常工作和学习中,我们经常需要从 excel 文件中读取数据。对于少量数据,手动复制和粘贴可能是可行的,但是对于大量的数据,这种方法会变得非常低效。在这种情况下,使用 Java 程序自动读取 Excel 文件中的数据将是更好的选择。

教程将介绍如何使用 Java 程序读取 Excel 文件中的数据,包括以下几个方面:

  1. 了解 Excel 文件格式
  2. 选择 Java 的 Excel 文件读取库
  3. 读取 Excel 文件中的数据
  4. 处理 Excel 文件中的不同数据类型
  5. 使用 Java 程序导出 Excel 文件

让我们开始吧!


1、了解 Excel 文件格式

在开始编写 Java 程序读取 Excel 文件之前,我们需要了解 Excel 文件格式。Excel 文件是基于 Microsoft 的 OLE2 格式的,这个格式将文件组织成一系列的 "容器" 和 "对象"。Excel 文件的主要容器是 Workbook,它包含一个或多个 Sheet。每个 Sheet 包含一组行和列,这些行和列组成了一个二维的单元格数组。每个单元格可以包含文本、数字、日期、布尔值等不同的数据类型。

2、选择 Java 的 Excel 文件读取库

在 Java 中,有多个库可以用于读取 Excel 文件。这些库包括 Apache POI、JExcelapi、EasyXLS、JXL 等。在本教程中,我们将使用 Apache POI 库。

Apache POI 是一个 Java API,用于操作 Microsoft 文档格式,包括 Word、Excel 和 PowerPoint。它提供了一组 Java 类,可以用于创建、读取和修改 Microsoft 文档。

3、读取 Excel 文件中的数据

在本节中,我们将演示如何使用 Apache POI 库读取 Excel 文件中的数据。

在开始之前,我们需要将 Apache POI 库添加到项目的依赖中。您可以通过 Maven 或 Gradle 等构建工具将它们添加到项目中。

以下是 Maven 项目的 pom.xml 文件中添加 Apache POI 库的示例代码:

    org.apache.poi    poi    4.1.2

以下是 Gradle 项目的 build.gradle 文件中添加 Apache POI 库的示例代码:

dependencies {    implementation 'org.apache.poi:poi:4.1.2'}

接下来,我们将演示如何使用 Apache POI 库读取 Excel 文件中的数据。

首先,我们需要创建一个 Workbook 对象,该对象表示整个 Excel 文件。在 Apache POI 中,Workbook 对象有三种不同的类型:HSSFWorkbook 表示一个 .xls 文件,XSSFWorkbook 表示一个 .xlsx 文件,SXSSFWorkbook 表示一个大型 .xlsx 文件。我们可以使用 WorkbookFactory.create() 方法根据文件的类型创建一个 Workbook 对象。以下是创建一个 XSSFWorkbook 对象的示例代码:

FileInputStream file = new FileInputStream(new File("path/to/excel/file.xlsx"));Workbook workbook = WorkbookFactory.create(file);

接下来,我们可以获取一个 Sheet 对象,该对象表示 Excel 文件中的一个工作表。在 Apache POI 中,Sheet 对象由 Workbook 对象的 getSheet() 方法返回。以下是获取名为 "Sheet1" 的 Sheet 对象的示例代码:

Sheet sheet = workbook.getSheet("Sheet1");

一旦我们获取了 Sheet 对象,我们就可以遍历其中的每一行和每一列,以读取其中的单元格数据。以下是遍历 Sheet 对象中的所有单元格并输出单元格值的示例代码:

Iterator rowIterator = sheet.iterator();while (rowIterator.hasNext()) {    Row row = rowIterator.next();    Iterator cellIterator = row.cellIterator();    while (cellIterator.hasNext()) {        Cell cell = cellIterator.next();        switch (cell.getCellType()) {            case STRING:                System.out.print(cell.getStrinGCellValue() + "\t");                break;            case NUMERIC:                System.out.print(cell.getNumericCellValue() + "\t");                break;            case BOOLEAN:                System.out.print(cell.getBooleanCellValue() + "\t");                break;            default:                System.out.print("\t");        }    }    System.out.println();}

上述代码中,我们使用了一个嵌套的迭代器来遍历每一行和每一列。在每个单元格中,我们使用 switch 语句根据不同的数据类型执行不同的操作。

4、处理 Excel 文件中的不同数据类型

在 Excel 文件中,单元格可以包含不同的数据类型,包括字符串、数字、日期和布尔值等。当我们读取单元格中的数据时,我们需要知道单元格中的数据类型,以正确地处理它们。

在 Apache POI 中,我们可以使用 Cell.getCellType() 方法获取单元格的数据类型。该方法返回 CellType 枚举类型的值,可以使用 switch 语句根据不同的枚举值执行不同的操作。

以下是使用 switch 语句处理不同数据类型的示例代码:

switch (cell.getCellType()) {    case STRING:        System.out.print(cell.getStringCellValue() + "\t");        break;    case NUMERIC:        if (DateUtil.isCellDateFORMatted(cell)) {            System.out.print(cell.getDateCellValue() + "\t");        } else {            System.out.print(cell.getNumericCellValue() + "\t");        }        break;    case BOOLEAN:        System.out.print(cell.getBooleanCellValue() + "\t");        break;    default:        System.out.print("\t");}

在上述示例代码中,我们首先检查单元格的数据类型是否为字符串。如果是字符串,我们使用 getStringCellValue() 方法获取字符串值。如果单元格的数据类型为数字,我们还需要检查单元格是否包含日期。如果是日期,我们使用 getDateCellValue() 方法获取日期值,否则我们使用 getNumericCellValue() 方法获取数字值。

5、使用 Java 程序导出 Excel 文件

除了读取 Excel 文件中的数据外,我们还可以使用 Java 程序创建和导出 Excel 文件。Apache POI 提供了 HSSFWorkbook 和 XSSFWorkbook 两个类,用于创建和操作 Excel 文件。

HSSFWorkbook 类用于操作旧版的 .xls 格式的 Excel 文件,而 XSSFWorkbook 类用于操作新版的 .xlsx 格式的 Excel 文件。我们可以根据需要选择合适的类来创建和导出 Excel 文件。

以下是创建和导出 Excel 文件的一般步骤:

  1. 创建一个 Workbook 对象,表示整个 Excel 文件。
  2. 创建一个 Sheet 对象,表示 Excel 文件中的一个工作表。
  3. 创建 Row 和 Cell 对象,表示 Excel 文件中的行和列。
  4. 为每个单元格设置数据和样式。
  5. 将 Workbook 对象写入文件或输出流中。

下面,让我们来看一些示例代码,演示如何使用 Java 程序创建和导出 Excel 文件。

  1. 创建一个 XSSFWorkbook 对象

以下是创建一个 XSSFWorkbook 对象的示例代码:

Workbook workbook = new XSSFWorkbook();Sheet sheet = workbook.createSheet("Sheet1");
  1. 创建行和单元格

以下是创建行和单元格的示例代码:

Row row = sheet.createRow(0);Cell cell = row.createCell(0);cell.setCellValue("Hello, World!");
  1. 设置单元格样式

在 Excel 文件中,我们可以为单元格设置不同的样式,包括字体、颜色、对齐方式等。以下是设置单元格样式的示例代码:

CellStyle style = workbook.createCellStyle();Font font = workbook.createFont();font.setBold(true);style.setFont(font);cell.setCellStyle(style);

在上述示例代码中,我们首先使用 createCellStyle() 方法创建一个单元格样式对象。然后,我们使用 createFont() 方法创建一个字体对象,并设置其属性。最后,我们将样式应用于单元格。

  1. 导出 Excel 文件

导出 Excel 文件时,我们可以将 Workbook 对象写入文件或输出流中。以下是将 Workbook 对象写入文件的示例代码:

FileOutputStream fileOut = new FileOutputStream("path/to/excel/file.xlsx");workbook.write(fileOut);fileOut.close();

在上述示例代码中,我们首先使用 FileOutputStream 类创建一个文件输出流对象。然后,我们使用 write() 方法将 Workbook 对象写入文件中。最后,我们关闭文件输出流。

除了写入文件,我们还可以将 Workbook 对象输出到网络流中,以便在浏览器中下载 Excel 文件。以下是将 Workbook 对象输出到网络流中的示例代码:

response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setHeader("Content-Disposition", "attachment; filename=\"excel_file.xlsx\"");OutputStream outputStream = response.getOutputStream();workbook.write(outputStream);outputStream.close();

在上述示例代码中,我们首先设置 Http 响应的内容类型和文件名。然后,我们使用 getOutputStream() 方法获取网络输出流对象。最后,我们使用 write() 方法将 Workbook 对象写入网络流中,并关闭输出流。

完整示例代码

下面是一个完整的示例代码,演示如何使用 Java 程序读取和导出 Excel 文件:

import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.IOException;import org.apache.poi.ss.usermodel.Cell;import org.apache.poi.ss.usermodel.CellType;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;import org.apache.poi.ss.usermodel.CellStyle;import org.apache.poi.ss.usermodel.Font;import org.apache.poi.xssf.usermodel.XSSFWorkbook;public class ExcelUtils {    public static void readExcel(String fileName) throws IOException {        // 创建文件输入流        FileInputStream fileInputStream = new FileInputStream(new File(fileName));        // 创建工作簿对象        Workbook workbook = WorkbookFactory.create(fileInputStream);        // 获取第一个工作表        Sheet sheet = workbook.getSheetAt(0);        // 遍历工作表中的所有行和单元格        for (Row row : sheet) {            for (Cell cell : row) {                // 根据单元格的类型读取数据                switch (cell.getCellType()) {                    case STRING:                        System.out.print(cell.getStringCellValue() + "\t");                        break;                    case NUMERIC:                        System.out.print(cell.getNumericCellValue() + "\t");                        break;                    case BOOLEAN:                        System.out.print(cell.getBooleanCellValue() + "\t");                        break;                    case FORMULA:                        System.out.print(cell.getCellFormula() + "\t");                        break;                    case BLANK:                        System.out.print("\t");                        break;                    default:                        System.out.print("\t");                }            }            System.out.println();        }        // 关闭文件输入流        fileInputStream.close();    }    public static void writeExcel(String fileName) throws IOException {        // 创建工作簿对象        Workbook workbook = new XSSFWorkbook();        Sheet sheet = workbook.createSheet("Sheet1");        // 创建行和单元格        Row row = sheet.createRow(0);        Cell cell = row.createCell(0);        cell.setCellValue("Hello, World!");        // 设置单元格样式        CellStyle style = workbook.createCellStyle();        Font font = workbook.createFont();        font.setBold(true);        style.setFont(font);        cell.setCellStyle(style);        // 导出 Excel 文件        FileOutputStream fileOut = new FileOutputStream(fileName);        workbook.write(fileOut);        fileOut.close();    }}

使用该类,我们可以方便地读取和导出 Excel 文件,如下所示:

public static void main(String[] args) throws IOException {    String fileName = "path/to/excel/file.xlsx";    // 读取 Excel 文件    ExcelUtils.readExcel(fileName);    // 导出 Excel 文件    ExcelUtils.writeExcel(fileName);}

6、结论

本文介绍了如何使用 Java 程序灵活读取和导出 Excel 文件。我们首先介绍了 Apache POI 库,它是 Java 操作 Office 文档的一个强大的工具。然后,我们演示了如何使用 POI 库读取 Excel 文件,并解释了如何根据单元如何设置单元格样式。最后,我们提供了一个完整的示例代码,演示了如何使用 ExcelUtils 类来读取和导出 Excel 文件。

Java 程序读取和导出 Excel 文件是一项非常实用的技能,尤其是在需要处理大量数据的项目中。使用 Apache POI 库,我们可以方便地读取和写入 Excel 文件,这可以大大提高我们的工作效率。

在实际应用中,我们需要根据具体的需求来选择读取和写入 Excel 文件的方法,以达到最好的效果。

参考文献

来源地址:https://blog.csdn.net/bairo007/article/details/131818662

--结束END--

本文标题: 如何使用 Java 灵活读取 Excel 内容?

本文链接: https://www.lsjlt.com/news/404260.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何使用 Java 灵活读取 Excel 内容?
    在日常工作和学习中,我们经常需要从 Excel 文件中读取数据。对于少量数据,手动复制和粘贴可能是可行的,但是对于大量的数据,这种方法会变得非常低效。在这种情况下,使用 Java 程序自动读取 Excel 文件中的数据将是更好的选择。 本教...
    99+
    2023-09-12
    java excel 开发语言
  • C#中如何读取Excel内容
    C#中如何读取Excel内容,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。(1) OleDb: 用这种方法读取Excel速度还是非常的快的,但这种方式读取数据的时候不太灵活...
    99+
    2023-06-17
  • Python如何读取Excel表内容
    用python读取excel表中的数据 假如说有如下一张存储了数据的excel表,其中x1-x6是特征,y_label是特征对应的类别标签。我们想要使用python对以下数据进行数据分析,那么第一步就...
    99+
    2023-09-02
    python 数据分析 数据挖掘
  • java怎么读取excel文件内容
    可以使用Apache POI库来读取Excel文件内容。首先,你需要下载并导入Apache POI库。你可以在官方网站(https:...
    99+
    2023-09-20
    java excel
  • 怎么用c#读取excel文件内容
    你可以使用Microsoft.Office.Interop.Excel命名空间下的Excel对象来读取Excel文件内容。 首先,你...
    99+
    2023-10-22
    C# excel
  • Python如何提取Excel内容
    这篇文章主要讲解了“Python如何提取Excel内容”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python如何提取Excel内容”吧!说实话,Python操作excel的库很多,但是我...
    99+
    2023-06-15
  • 怎么使用java读取文件内容
    在Java中可以使用File类和Scanner类来读取文件内容。下面是一个简单的示例: import java.io.File; i...
    99+
    2024-04-02
  • 如何用vbs读取index.dat内容
    本篇内容介绍了“如何用vbs读取index.dat内容”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!复制代码 代码如下:' +---...
    99+
    2023-06-08
  • 如何使用ADO.NET Excel读取文件
    小编给大家分享一下如何使用ADO.NET Excel读取文件,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在关系数据库提供的各种对象中(表、视图、存储过程等),E...
    99+
    2023-06-17
  • java如何读取word文档表格内容
    要读取Word文档中的表格内容,可以使用Apache POI库来处理Word文档。以下是一个简单的示例代码,演示如何读取Word文档...
    99+
    2023-09-22
    java word
  • java如何读取excel表数据
    在Java中读取Excel表的数据,可以使用Apache POI库来实现。Apache POI是一个流行的Java库,用于读写Mic...
    99+
    2023-09-22
    java excel
  • 利用Python读取Excel表内容的详细过程
    目录用python读取excel表中的数据这里再多说一下,np.hstack()函数和 np.vstack()函数:总结用python读取excel表中的数据 假如说有如下一张存储了...
    99+
    2024-04-02
  • C语言读取TXT文件内容如何使用
    在C语言中,可以使用标准库函数fopen()来打开文件,并使用fscanf()或者fgets()函数来读取文件内容。 下面是一个示例...
    99+
    2024-02-29
    C语言
  • TXT文件的内容如何利用Java实现读取
    本篇文章为大家展示了TXT文件的内容如何利用Java实现读取,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Java读取txt文件内容。可以作如下理解:首先获得一个文件句柄。File file = n...
    99+
    2023-05-31
    java ava txt
  • php如何读取文件内容
    在PHP中,可以使用`file_get_contents()`函数来读取文件内容。该函数接受一个参数,即要读取的文件的路径,返回文件...
    99+
    2023-08-15
    php
  • python如何读取文件内容
    在Python中,可以使用`open()`函数来打开一个文件,并使用`.read()`方法来读取文件的内容。以下是一个示例:```p...
    99+
    2023-08-25
    python
  • python如何使用xlrd模块读取excel
    这篇文章主要介绍了python如何使用xlrd模块读取excel,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、安装xlrd模块:mac下打开终端输入命令:pip ...
    99+
    2023-06-29
  • Python如何提取Excel文本框内容
    这期内容当中小编将会给大家带来有关Python如何提取Excel文本框内容,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。说实话,这个需求头一次碰到,我相信对于大多数朋友来说,也是头一次碰到。“提取exce...
    99+
    2023-06-15
  • Java如何不解压读取.zip的文件内容
    前言 最近项目中需要拿到.zip文件中的文件内容,之前的做法是先解压到某个目录然后在对里面的文件进行处理,后面发现其实可以不用这么做,jdk中自带的包就可以解决这个问题。 示例如下:...
    99+
    2024-04-02
  • Java如何使用jxl读取excel并保存到数据库
    小编给大家分享一下Java如何使用jxl读取excel并保存到数据库,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!项目中涉及到读取excel中的数据,保存到数据库...
    99+
    2023-05-31
    java jxl excel
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作