Java自动化实现在Excel工作表中创建、修改和删除表格

 更新时间:2025年09月26日 08:26:15   作者:缺点内向  
在Java应用中,我们经常需要动态处理Excel里的表格,本文将使用Spire.XLS for Java轻松搞定表格的创建、修改和删除操作,需要的可以了解下

在Java应用中,我们经常需要动态处理Excel里的表格。比如自动生成一个带格式的数据报表,或者调整现有表格的范围。使用Spire.XLS for Java,这几行代码就能搞定表格的创建、修改和删除,让繁琐的手动操作彻底自动化。

1. 轻松创建 Excel 表格

在Excel中创建表格,不仅能使数据结构化、易于阅读,还能自动获得筛选、排序、汇总等功能。使用Spire.XLS for Java,创建表格变得异常简单。

Spire.XLS for Java 实现

创建表格的核心步骤是指定数据范围,并为表格命名。我们还可以为表格应用预设的样式,使其外观更专业。

代码示例

import com.spire.xls.*;
import com.spire.xls.collections.IListObjects;
import com.spire.xls.core.IListObject;

public class CreateExcelTable {
    public static void main(String[] args) {
        // 1. 创建一个新的工作簿
        Workbook workbook = new Workbook();
        // 2. 获取第一个工作表
        Worksheet sheet = workbook.getWorksheets().get(0);

        // 3. 填充一些示例数据
        sheet.getCellRange("A1").setText("产品");
        sheet.getCellRange("B1").setText("数量");
        sheet.getCellRange("C1").setText("单价");
        sheet.getCellRange("D1").setText("总价");

        sheet.getCellRange("A2").setText("键盘");
        sheet.getCellRange("B2").setNumberValue(10);
        sheet.getCellRange("C2").setNumberValue(120.50);
        sheet.getCellRange("D2").setFormula("=B2*C2"); // 使用公式

        sheet.getCellRange("A3").setText("鼠标");
        sheet.getCellRange("B3").setNumberValue(20);
        sheet.getCellRange("C3").setNumberValue(60.00);
        sheet.getCellRange("D3").setFormula("=B3*C3");

        // 4. 在指定数据区域创建表格,并命名为 "销售数据表"
        // 参数1: 表格名称
        // 参数2: 数据范围
        IListObject table = sheet.getListObjects().create("销售数据表", sheet.getCellRange("A1:D3"));

        // 5. 应用内置表格样式(例如:浅色样式9)
        table.setBuiltInTableStyle(TableBuiltInStyles.TableStyleLight9);

        // 6. 启用筛选功能 (默认情况下表格会启用)
        table.setShowHeaderRow(true); // 显示标题行
        table.setShowTotalsRow(false); // 默认不显示汇总行

        // 7. 保存工作簿
        workbook.saveToFile("CreateExcelTable.xlsx", ExcelVersion.Version2016);
        System.out.println("Excel表格 '销售数据表' 已成功创建!");
    }
}

关键点提示

  • sheet.getListObjects().create() 方法是创建表格的核心,它允许你指定表格的名称和数据范围。
  • setBuiltInTableStyle() 可以为表格快速应用Excel内置的多种样式,提升美观度。
  • setShowHeaderRow()setShowTotalsRow() 可以控制表格是否显示标题行和汇总行。

2. 灵活修改 Excel 表格

表格创建后,我们常常需要进行修改,例如添加新的数据行、更新现有数据、调整表格样式,甚至添加汇总行等。

Spire.XLS for Java 实现

Spire.XLS for Java 提供了方便的API来访问工作表中的现有表格对象,进而对其进行各种修改。

代码示例

本例将演示如何向现有表格添加新行数据,并启用汇总行功能。

import com.spire.xls.*;
import com.spire.xls.core.IListObject;

public class ModifyExcelTable {
    public static void main(String[] args) {
        // 1. 加载一个包含表格的Excel文件
        Workbook workbook = new Workbook();
        workbook.loadFromFile("CreateExcelTable.xlsx"); // 使用上一步创建的文件

        // 2. 获取第一个工作表
        Worksheet sheet = workbook.getWorksheets().get(0);

        // 3. 获取工作表中的第一个表格(通过索引或名称)
        IListObject table = sheet.getListObjects().get(0); // 假设只有一个表格

        // 4. 添加新数据行到表格下方
        int lastRow = table.getRange().getLastRow(); // 获取表格当前数据的最后一行
        sheet.getCellRange("A" + (lastRow + 1)).setText("显示器");
        sheet.getCellRange("B" + (lastRow + 1)).setNumberValue(5);
        sheet.getCellRange("C" + (lastRow + 1)).setNumberValue(800.00);
        sheet.getCellRange("D" + (lastRow + 1)).setFormula("=B" + (lastRow + 1) + "*C" + (lastRow + 1));

        // 5. 调整表格的数据范围以包含新添加的行
        // 注意:Spire.XLS会自动扩展表格区域以包含新增数据,如果新增数据紧邻表格下方。
        // 但为了严谨性,也可以手动更新表格的Range,或通过添加ListRow的方式
        // 示例:这里我们直接添加数据,Spire.XLS通常会自动识别并扩展表格。

        // 6. 启用表格的汇总行 (Total Row)
        table.setShowTotalsRow(true);

        // 7. 设置汇总行的计算方式 (例如,对 "总价" 列求和)
        // 假设 "总价" 是表格的第四列 (索引为3)
        // 注意:TotalsCalculation枚举定义了多种计算方式,如Sum, Average, Count等。
        table.getColumns().get(3).setTotalsCalculation(ExcelTotalsCalculation.Sum);
        // 可以为汇总行第一个单元格设置标签
        table.getColumns().get(0).setTotalsRowLabel("总计:");


        // 8. 保存修改后的工作簿
        workbook.saveToFile("ModifiedExcelTable.xlsx", ExcelVersion.Version2016);
        System.out.println("Excel表格已成功修改,添加新行并启用汇总!");
    }
}

关键点提示

  • sheet.getListObjects().get(index)sheet.getListObjects().getByName(name) 可以获取到工作表中的特定表格对象。
  • 通过直接操作 sheet.getCellRange() 并紧邻表格数据区域下方添加数据,Spire.XLS通常会自动扩展表格范围。
  • setShowTotalsRow(true) 启用汇总行,getColumns().get(columnIndex).setTotalsCalculation() 则指定各列的汇总计算方式。

3. 有效删除 Excel 表格

当不再需要某个表格时,我们可以选择将其删除。删除表格意味着取消其结构化特性,但通常会保留其数据内容(变为普通单元格区域)。

Spire.XLS for Java 实现

删除表格是一个相对简单的操作,只需获取到表格对象,然后调用其 remove() 方法即可。

代码示例

import com.spire.xls.*;
import com.spire.xls.core.IListObject;

public class DeleteExcelTable {
    public static void main(String[] args) {
        // 1. 加载一个包含表格的Excel文件
        Workbook workbook = new Workbook();
        workbook.loadFromFile("ModifiedExcelTable.xlsx"); // 使用上一步修改的文件

        // 2. 获取第一个工作表
        Worksheet sheet = workbook.getWorksheets().get(0);

        // 3. 获取要删除的表格对象 (例如,通过名称 "销售数据表")
        IListObject tableToDelete = sheet.getListObjects().getByName("销售数据表");

        // 4. 删除表格
        if (tableToDelete != null) {
            tableToDelete.remove();
            System.out.println("Excel表格 '销售数据表' 已成功删除!");
        } else {
            System.out.println("未找到名为 '销售数据表' 的表格。");
        }

        // 5. 保存修改后的工作簿
        workbook.saveToFile("DeletedExcelTable.xlsx", ExcelVersion.Version2016);
    }
}

注意事项

  • tableToDelete.remove() 方法会删除表格的结构和功能(如筛选、样式等),但表格内的数据会保留在单元格中,成为普通的数据区域。
  • 在执行删除操作前,最好进行非空检查,确保要删除的表格确实存在。

总结

无论是批量生成带有特定样式的表格、动态更新数据、添加汇总行,还是按需移除不再需要的表格,Java Excel Automation 借助 Spire.XLS for Java 都能轻松应对。掌握这些技能,将能有效提升你在数据处理、报表生成等方面的开发效率,解决实际工作中遇到的痛点。

到此这篇关于Java自动化实现在Excel工作表中创建、修改和删除表格的文章就介绍到这了,更多相关Java操作Excel工作表内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot配置文件密码加密与解密的操作代码

    SpringBoot配置文件密码加密与解密的操作代码

    我们在SpringBoot项目当中,会把数据库的用户名密码等配置直接放在yaml或者properties文件中,这样维护数据库的密码等敏感信息显然是有一定风险的,所以我们需要给密码加解密,本文给大家介绍了SpringBoot配置文件密码加密与解密的操作代码,需要的朋友可以参考下
    2024-12-12
  • SpringBoot使用thymeleaf实现前端表格

    SpringBoot使用thymeleaf实现前端表格

    虽然现在流行前后端分离,但是后端模版在一些关键地方还是非常有用的,例如邮件模版、代码模版等。当然也不排除一些古老的项目后端依然使用动态模版。Thymeleaf 简洁漂亮、容易理解,并且完美支持 HTML5,可以直接打开静态页面,同时不新增标签,只需增强属性
    2022-10-10
  • MyBatis-Plus插件机制及通用Service新功能

    MyBatis-Plus插件机制及通用Service新功能

    这篇文章主要介绍了MyBatis-Plus插件机制以及通用Service、新功能,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • 实例讲解java的纯数字加密解密

    实例讲解java的纯数字加密解密

    本文给大家分享的是一个java纯数字加密解密技术,加密和解密本身就是一对共生体,缺一不可,需要的朋友可以参考下
    2015-07-07
  • Java反射获取所有Controller和RestController类的方法

    Java反射获取所有Controller和RestController类的方法

    这篇文章给大家分享了Java反射获取所有Controller和RestController类的方法,文中有详细的代码示例讲解,具有一定的参考价值,需要的朋友可以参考下
    2023-08-08
  • AsyncHttpClient exception异常源码流程解析

    AsyncHttpClient exception异常源码流程解析

    这篇文章主要为大家介绍了AsyncHttpClient的exception源码流程解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-12-12
  • 使用mybatis切片实现数据权限控制的操作流程

    使用mybatis切片实现数据权限控制的操作流程

    数据权限控制需要对查询出的数据进行筛选,对业务入侵最少的方式就是利用mybatis或者数据库连接池的切片对已有业务的sql进行修改,本文给大家介绍了使用mybatis切片实现数据权限控制的操作流程,需要的朋友可以参考下
    2024-07-07
  • 如何基于回调实现Java的异步调用

    如何基于回调实现Java的异步调用

    这篇文章主要介绍了如何基于回调实现Java的异步调用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • SpringBoot+MyBatis Plus实现update_time字段自动更新详解

    SpringBoot+MyBatis Plus实现update_time字段自动更新详解

    在 Spring Boot + MyBatis Plus 中实现 update_time 字段自动更新,可通过 ​​MyBatis Plus 的自动填充(Auto Fill)功能​​ 完成,下面小编就来和大家详细介绍一下吧
    2025-07-07
  • 使用Java读取Word文件的简单例子分享

    使用Java读取Word文件的简单例子分享

    这篇文章主要介绍了使用Java读取Word文件的简单例子分享,包括读取word文件的表格数据的示例,需要的朋友可以参考下
    2015-10-10

最新评论