news 2026/5/1 8:47:08

快速创建与读取 Excel:Java 开发者必备的 Spire.XLS 实战技巧

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
快速创建与读取 Excel:Java 开发者必备的 Spire.XLS 实战技巧

在现代软件开发中,Excel 文档的管理和操作是一个常见的需求。无论是在数据分析、报表生成,还是在管理信息系统中,Excel 都扮演着重要的角色。本文将介绍如何使用 Spire.XLS for Java 库,以便轻松地读写 Excel 文档。

Spire.XLS for Java 简介

Spire.XLS 是一款强大的 Java Excel 组件,支持高效的 Excel 文件创建、编辑、读取和转换功能。无论是 .xlsx 还是 .xls 格式的文件,这个库都能轻松处理。它不仅提供了广泛的 API,还具备快速的性能和良好的文档支持,使得开发者在处理表格时更加高效。

使用 Maven 安装 Spire.XLS for Java

如果你的项目使用 Maven 作为构建工具,可以通过在 pom.xml 文件中添加以下依赖来安装 Spire.XLS:

<repositories> <repository> <id>com.e-iceblue</id> <name>e-iceblue</name> <url>https://repo.e-iceblue.com/nexus/content/groups/public/</url> </repository> </repositories> <dependencies> <dependency> <groupId>e-iceblue</groupId> <artifactId>spire.xls</artifactId> <version>15.12.15</version> </dependency> </dependencies>

这样,Maven 会自动下载并包含所需的库文件,方便你在项目中使用。

读取 Excel 文件

在这一部分,我们将介绍如何读取 Excel 文件中的数据。以下是一个简单的示例代码,展示了如何加载已有的 Excel 文件,并输出其内容。

import com.spire.xls.CellRange; import com.spire.xls.Workbook; import com.spire.xls.Worksheet; public class ReadData { public static void main(String[] args) { // 创建一个 Workbook 对象 Workbook wb = new Workbook(); // 加载现有的 Excel 文件 wb.loadFromFile("C:/Users/Administrator/Desktop/NewSpreadsheet.xlsx"); // 获取第一个工作表 Worksheet sheet = wb.getWorksheets().get(0); // 获取包含数据的单元格范围 CellRange locatedRange = sheet.getAllocatedRange(); // 遍历行 for (int i = 0; i < locatedRange.getRows().length; i++) { // 遍历列 for (int j = 0; j < locatedRange.getColumnCount(); j++) { // 获取特定单元格的数据 System.out.print(locatedRange.get(i + 1, j + 1).getValue() + " "); } System.out.println(); } } }

代码解析

  1. Workbook 对象:创建一个Workbook对象,用于加载 Excel 文件。
  2. 加载文件:通过loadFromFile方法加载存在的 Excel 文件。
  3. 获取工作表:通过getWorksheets().get(0)方法获得第一个工作表。
  4. 遍历数据:使用双重循环遍历每一行和每一列,打印出单元格中的值。

写入 Excel 文件

接下来,我们将展示如何创建新的 Excel 文件,设置工作表的基本信息,并写入数据。

import com.spire.xls.*; public class CreateSpreadsheet { public static void main(String[] args) { // 创建一个 Workbook 对象 Workbook wb = new Workbook(); // 移除默认工作表 wb.getWorksheets().clear(); // 添加一个名为 "员工" 的工作表 Worksheet sheet = wb.getWorksheets().add("员工"); // 合并 A1 到 G1 的单元格 sheet.getRange().get("A1:G1").merge(); // 向 A1 写入数据并应用格式 sheet.getRange().get("A1").setValue("华宇汽车公司员工基本信息"); sheet.getRange().get("A1").setHorizontalAlignment(HorizontalAlignType.Center); sheet.getRange().get("A1").setVerticalAlignment(VerticalAlignType.Center); sheet.getRange().get("A1").getStyle().getFont().isBold(true); sheet.getRange().get("A1").getStyle().getFont().setSize(13); // 设置第一行的高度 sheet.setRowHeight(1, 30); // 创建一个二维数组 String[][] twoDimensionalArray = new String[][]{ {"姓名", "性别", "出生日期", "学历", "联系电话", "职位", "编号"}, {"艾伦", "男", "1990-02-10", "本科", "24756854", "机械师", "0021"}, {"帕特里克", "男", "1985-06-08", "硕士", "59863247", "机械师", "0022"}, {"珍娜", "女", "1989-11-25", "本科", "79540352", "销售", "0023"}, {"汤米", "男", "1988-04-16", "硕士", "52014060", "机械师", "0024"}, {"克里斯蒂娜", "女", "1998-01-21", "本科", "35401489", "人力资源", "0025"} }; // 从数组导入数据到工作表 sheet.insertArray(twoDimensionalArray, 2, 1); // 设置一个范围的行高 sheet.getRange().get("A2:G7").setRowHeight(15); // 设置列宽 sheet.setColumnWidth(2, 15); sheet.setColumnWidth(3, 21); sheet.setColumnWidth(4, 15); // 设置边框样式 sheet.getRange().get("A2:G7").borderAround(LineStyleType.Medium); sheet.getRange().get("A2:G7").borderInside(LineStyleType.Thin); sheet.getRange().get("A2:G2").borderAround(LineStyleType.Medium); sheet.getRange().get("A2:G7").getBorders().setKnownColor(ExcelColors.Black); // 保存为 .xlsx 文件 wb.saveToFile("output/NewSpreadsheet.xlsx", FileFormat.Version2016); } }

代码解析

  1. Workbook 对象:创建一个新的 Workbook 对象。
  2. 删除默认工作表:通过 clear 方法删除默认的工作表。
  3. 添加工作表:创建一个名为 "员工" 的工作表。
  4. 合并单元格:合并 A1 到 G1 的单元格。
  5. 写入数据:设置 A1 单元格的值,并调整其格式。
  6. 插入数组数据:将二维数组的数据插入到工作表中。
  7. 设置边框和格式:设置行高、列宽及单元格的边框样式。
  8. 保存文件:将工作簿保存为一个新的 Excel 文件。

总结

通过使用 Spire.XLS for Java 程序库,我们可以方便地处理 Excel 文档。无论是读取已有的数据,还是生成新的表格,Spire.XLS 都提供了极大的便利。它简单易用的 API 和丰富的功能特性,使得 Java 开发者能够轻松实现各种 Excel 操作。希望本文能够帮助你快速上手,也期待你在实际应用中发现它的更多潜能。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/29 15:48:45

DiskInfo下载官网替代方案:监控GPU存储状态以优化PyTorch训练

DiskInfo下载官网替代方案&#xff1a;监控GPU存储状态以优化PyTorch训练 在深度学习模型日益庞大的今天&#xff0c;一个常见的场景是&#xff1a;你启动了训练脚本&#xff0c;满怀期待地等待结果&#xff0c;几分钟后却突然收到一条冷冰冰的错误提示——CUDA out of memory。…

作者头像 李华
网站建设 2026/4/30 10:14:29

清华镜像源加速PyTorch安装:高效配置GPU训练环境技巧

清华镜像源加速PyTorch安装&#xff1a;高效配置GPU训练环境技巧 在人工智能项目开发中&#xff0c;最让人头疼的往往不是模型设计本身&#xff0c;而是环境搭建——尤其是当你面对“下载卡在30%”、“CUDA版本不匹配导致ImportError”这类问题时。一个本该十分钟完成的依赖安…

作者头像 李华
网站建设 2026/4/28 3:36:17

CNN手写数字识别实战:基于PyTorch-CUDA-v2.7快速上手

CNN手写数字识别实战&#xff1a;基于PyTorch-CUDA-v2.7快速上手 在深度学习初学者的“成长路线图”中&#xff0c;MNIST 手写数字识别几乎是一个绕不开的起点。它像是一把钥匙&#xff0c;打开了理解神经网络工作原理的大门。但真正动手时&#xff0c;很多人却被挡在了门外——…

作者头像 李华
网站建设 2026/5/1 9:48:15

AI 如何 “会写” 代码,甚至aardio这种小众语言也支持?

1. AI 如何 “会写” 代码AI&#xff08;尤其是大型语言模型&#xff0c;如 GPT 系列&#xff09;是通过学习海量文本数据来掌握语言和知识的。训练数据中不仅包括自然语言文本&#xff08;如书籍、网页、论文&#xff09;&#xff0c;还包含大量的开源代码库、技术文档、论坛讨…

作者头像 李华
网站建设 2026/4/28 22:11:37

Anaconda配置PyTorch环境全攻略:支持CUDA加速的实战指南

Anaconda配置PyTorch环境全攻略&#xff1a;支持CUDA加速的实战指南 在深度学习项目启动前&#xff0c;最让人头疼的往往不是模型设计&#xff0c;而是环境搭建——明明代码写好了&#xff0c;却因为torch.cuda.is_available()返回False而卡住&#xff1b;或者好不容易装上了Py…

作者头像 李华
网站建设 2026/4/29 13:26:34

网页编辑器导入Word文档图片并自动上传组件

咱安徽程序员实锤了&#xff01;最近接了个CMS外包活&#xff0c;客户是做企业官网的&#xff0c;非要给后台新闻编辑器加“文档导入Word一键粘贴”功能——好家伙&#xff0c;需求单写着“要保留Word里的花里胡哨样式&#xff0c;图片、公式、甚至MathType的鬼画符都得给我原模…

作者头像 李华