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 开发人员必备的一个工具库。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Java Maven专题
Java Maven专题

本专题聚焦 Java 主流构建工具 Maven 的学习与应用,系统讲解项目结构、依赖管理、插件使用、生命周期与多模块项目配置。通过企业管理系统、Web 应用与微服务项目实战,帮助学员全面掌握 Maven 在 Java 项目构建与团队协作中的核心技能。

0

2025.09.15

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

782

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

434

2024.06.27

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1901

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2091

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1072

2024.11.28

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1132

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

213

2025.10.17

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

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

精品课程

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

共23课时 | 3万人学习

C# 教程
C# 教程

共94课时 | 7.9万人学习

Java 教程
Java 教程

共578课时 | 53万人学习

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

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