0

0

Java API 开发中使用 Apache POI 进行 Excel 处理

WBOY

WBOY

发布时间:2023-06-18 12:17:54

|

1673人浏览过

|

来源于php中文网

原创

随着信息化的发展,数据处理的重要性不断凸显。而对于企业和个人而言,excel 工作表已经成为日常工作中最常用的一种数据处理方式。然而,excel 工作表虽然易于使用,但随着数据量和处理需求的增加,普通的 excel 处理方法往往难以满足实际应用需求。此时,java api 开发中使用 apache poi 库进行 excel 处理便成为了一种优秀的选择。

一、Apache POI 简介

Apache POI(Poor Obfuscation Implementation)是一个免费的 Java 库,用于处理和操作 Microsoft Office 格式的文件,其中包括 Word、Excel 和 PowerPoint 等文件。通过 Apache POI,Java 编程人员可以轻松地读取、编写和操作 Office 文件。

Apache POI 大致可分为三个部分:

  • HSSF(Horrible Spreadsheet Format):处理 Excel 97-2003 文件,即 xls 格式;
  • XSSF(XML Spreadsheet Format):处理 Excel 2007 及以上版本的文件,即 xlsx 格式;
  • HWPF(Horrible Word Processor Format)和 XWPF(XML Word Processor Format):分别处理 Word 97-2003 格式的文件和 Word 2007 及以上版本的文件。

本篇文章主要着重介绍 HSSF 和 XSSF 的使用。

立即学习Java免费学习笔记(深入)”;

二、POI 的安装

在使用 Apache POI 进行 Excel 处理前,我们需要先安装该库。Apache POI 的安装比较简单,只需要下载其最新版本的 jar 包,并将其添加到项目的 classpath 中即可。推荐使用 Maven 或 Gradle 等工具进行 POI 的引入,这样可以避免由于版本冲突等问题导致的异常。

三、读取 Excel 文件

读取 Excel 文件是 Apache POI 应用中最基本的操作之一。下面是读取 xlsx 文件的示例代码。

赣极购物商城网店建站软件系统
赣极购物商城网店建站软件系统

大小仅1兆左右 ,足够轻便的商城系统; 易部署,上传空间即可用,安全,稳定; 容易操作,登陆后台就可设置装饰网站; 并且使用异步技术处理网站数据,表现更具美感。 前台呈现页面,兼容主流浏览器,DIV+CSS页面设计; 如果您有一定的网页设计基础,还可以进行简易的样式修改,二次开发, 发布新样式,调整网站结构,只需修改css目录中的css.css文件即可。 商城网站完全独立,网站源码随时可供您下载

下载
public static void readXlsx(String filePath) throws IOException {
    FileInputStream fis = new FileInputStream(filePath);
    XSSFWorkbook workbook = new XSSFWorkbook(fis); // 创建工作簿
    XSSFSheet sheet = workbook.getSheetAt(0); // 获取第一个工作表
    int rowStartIndex = sheet.getFirstRowNum(); // 获取第一行的行号
    int rowEndIndex = sheet.getLastRowNum(); // 获取最后一行的行号
    for (int i = rowStartIndex; i <= rowEndIndex; i++) { // 循环行
        XSSFRow row = sheet.getRow(i); // 获取当前行
        if (row == null) { // 若为空行则跳过
            continue;
        }
        int cellStartIndex = row.getFirstCellNum(); // 获取第一列的列号
        int cellEndIndex = row.getLastCellNum() - 1; // 获取最后一列的列号
        for (int j = cellStartIndex; j <= cellEndIndex; j++) { // 循环列
            XSSFCell cell = row.getCell(j); // 获取当前单元格
            String cellValue = cell.getStringCellValue(); // 获取当前单元格的值
            System.out.print(cellValue + "  "); // 输出到控制台
        }
        System.out.println();
    }
    workbook.close(); // 关闭工作簿
    fis.close(); // 关闭输入流
}

在这段代码中,我们首先使用 FileInputStream 打开 xlsx 文件,并利用 XSSFWorkbook 创建工作簿。然后,我们获取第一个工作表,并使用循环逐行和逐列读取文件中的内容,将每个单元格的值输出到控制台。最后,我们需要关闭工作簿和输入流来释放资源。

读取 xls 文件与读取 xlsx 文件基本相同,只需要将 XSSF 相关的代码改成 HSSF 就可以了。

四、写入 Excel 文件

写入 Excel 文件也是 Apache POI 应用中常用的操作之一。下面是写入 xlsx 文件的示例代码。

public static void writeXlsx(String filePath) throws IOException {
    XSSFWorkbook workbook = new XSSFWorkbook(); // 创建工作簿
    XSSFSheet sheet = workbook.createSheet("Sheet1"); // 创建工作表
    XSSFRow row0 = sheet.createRow(0); // 创建第一行
    XSSFCell cell00 = row0.createCell(0); // 创建第一个单元格
    cell00.setCellValue("姓名"); // 设置单元格的值
    XSSFCell cell01 = row0.createCell(1); // 创建第二个单元格
    cell01.setCellValue("年龄"); // 设置单元格的值
    XSSFRow row1 = sheet.createRow(1); // 创建第二行
    XSSFCell cell10 = row1.createCell(0); // 创建第一个单元格
    cell10.setCellValue("张三"); // 设置单元格的值
    XSSFCell cell11 = row1.createCell(1); // 创建第二个单元格
    cell11.setCellValue(20); // 设置单元格的值
    XSSFRow row2 = sheet.createRow(2); // 创建第三行
    XSSFCell cell20 = row2.createCell(0); // 创建第一个单元格
    cell20.setCellValue("李四"); // 设置单元格的值
    XSSFCell cell21 = row2.createCell(1); // 创建第二个单元格
    cell21.setCellValue(25); // 设置单元格的值
    FileOutputStream fos = new FileOutputStream(filePath);
    workbook.write(fos); // 输出文件
    workbook.close(); // 关闭工作簿
    fos.close(); // 关闭输出流
}

在这段代码中,我们创建了一个 xlsx 文件,并在其中创建了一个名为 "Sheet1" 的工作表。接着,我们在表格中添加了三行数据,每行分别包含两个单元格。最后,我们将文件输出到指定的文件路径,并关闭工作簿和输出流来释放资源。

写入 xls 文件与写入 xlsx 文件基本相同,只需要将 XSSF 相关的代码改成 HSSF 就可以了。

五、总结

通过本文的讲解,读者可以初步了解 Apache POI 在 Java API 开发中的使用,特别是在 Excel 文件处理方面的应用。无论是读取 Excel 文件还是写入 Excel 文件,Apache POI 都提供了易于使用的接口,使得 Java 编程人员能够轻松地进行 Excel 文件的操作。同时,Apache POI 还支持 Word 和 PowerPoint 等 Office 文件的处理,是 Java 开发人员必备的一个工具库。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

804

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

723

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

727

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

395

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

445

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

428

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16861

2023.08.03

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

3

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.1万人学习

C# 教程
C# 教程

共94课时 | 5.7万人学习

Java 教程
Java 教程

共578课时 | 39.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号