用Python在Excel工作表中创建、修改及删除表格区域

在数据分析和自动化处理的工作中,Excel作为一种强大的工具被广泛应用,而通过Python来操作Excel工作表中的表格,可以极大提高工作效率。表格(Table)是Excel中的一种重要结构,它是一个特殊的单元格区域,不仅能帮助我们组织和展示数据,还能提供便捷的数据筛选、排序和分析功能。使用Python,我们可以在Excel工作表中轻松创建、修改或删除这些表格 ,进而实现批量处理、动态更新以及自定义报告的自动生成。本文将介绍如何使用Python在Excel工作表中创建、修改及删除表格

文章目录

本文所使用的方法需要用到Spire.XLS for Python,PyPI:pip install spire.xls

用Python在Excel工作表中创建表格

我们可以使用Worksheet.ListObjects.Create(string: tableName, CellRange: cellRange)方法,指定表名和单元格范围,直接在Excel工作表中创建表格。以下是操作步骤示例:

  1. 导入所需模块:WorkbookTableBuiltInStyles(用于应用内置表格样式)。
  2. 创建一个Workbook实例。
  3. 使用Workbook.LoadFromFile()方法载入Excel文件。
  4. 使用Workbook.Worksheets.get_Item()获取指定工作表。
  5. 使用Worksheet.Range.get_Item()方法获取用于创建表格的单元格区域。
  6. 使用Worksheet.ListObjects.Create(string: tableName, CellRange: cellRange)方法创建表格。
  7. 根据需要设置表格格式。
  8. 使用Workbook.SaveToFile()方法保存更改。
  9. 释放资源。

代码示例

python 复制代码
from spire.xls import Workbook, TableBuiltInStyles

# 创建一个Workbook实例
workbook = Workbook()

# 加载Excel文件
workbook.LoadFromFile("Sample.xlsx")

# 获取工作表
sheet = workbook.Worksheets.get_Item(0)

# 获取表格的单元格范围
cellRange = sheet.Range.get_Item("A1:F9")

# 创建表格
table = sheet.ListObjects.Create("Table1", cellRange)

# 格式化表格
table.BuiltInTableStyle = TableBuiltInStyles.TableStyleLight17

# 保存工作簿
workbook.SaveToFile("output/CreateTableExcel.xlsx")
workbook.Dispose()

结果

用Python修改Excel工作表中的表格

我们可以使用Worksheet.ListObjects.get_Item()方法根据索引从工作表中获取表格对象,然后使用其下的属性对表格进行修改,如修改所在单元格区域、是否显示表头、表格名。以下是操作步骤示例:

  1. 导入所需模块:WorkbookTableBuiltInStyles(用于修改内置表格样式)。
  2. 创建一个Workbook实例。
  3. 使用Workbook.LoadFromFile()方法载入Excel文件。
  4. 使用Workbook.Worksheets.get_Item()获取指定工作表。
  5. 使用Worksheet.ListObjects.get_Item()方法从工作表中获取表格。
  6. 使用其下的属性对表格进行修改。
  7. 使用Workbook.SaveToFile()方法保存更改。
  8. 释放资源。

代码示例

python 复制代码
from spire.xls import Workbook, TableBuiltInStyles

# 创建一个Workbook实例
workbook = Workbook()

# 加载Excel文件
workbook.LoadFromFile("output/CreateTableExcel.xlsx")

# 获取第一个工作表
sheet = workbook.Worksheets.get_Item(0)

# 获取第一个表格
table = sheet.ListObjects.get_Item(0)

# 使用IListObject类的属性修改表格
table.Location = sheet.Range.get_Item("A1:C9")
table.DisplayHeaderRow = False
table.BuiltInTableStyle = TableBuiltInStyles.TableStyleDark5
table.Name = "NewTable"

# 保存工作簿
workbook.SaveToFile("output/ModifyTableExcel.xlsx")
workbook.Dispose()

结果

用Python移除Excel工作表中的表格

使用Worksheet.ListObjects.RemoveAt()方法可以根据索引从Excel工作表中删除指定表格,从而将其转变为普通单元格区域,并移除表格格式。以下是操作步骤示例:

  1. 导入所需模块:Workbook
  2. 创建一个Workbook实例。
  3. 使用Workbook.LoadFromFile()方法载入Excel文件。
  4. 使用Worksheet.ListObjects.RemoveAt()方法根据索引删除指定表格。
  5. 使用Workbook.SaveToFile()方法保存更改。
  6. 释放资源。

代码示例

python 复制代码
from spire.xls import Workbook, TableBuiltInStyles

# 创建一个Workbook实例
workbook = Workbook()

# 加载Excel文件
workbook.LoadFromFile("output/ModifyTableExcel.xlsx")

# 获取第一个工作表
sheet = workbook.Worksheets.get_Item(0)

# 从工作表中移除一个表格
sheet.ListObjects.RemoveAt(0)

# 保存工作簿
workbook.SaveToFile("output/RemoveTableExcel.xlsx")
workbook.Dispose()

结果

本文演示如何使用Python在Excel工作表中创建、修改及删除表格。

申请免费License

相关推荐
她说..2 小时前
Java 对象相关高频面试题
java·开发语言·spring·java-ee
花酒锄作田2 小时前
Postgres - Listen/Notify构建轻量级发布订阅系统
python·postgresql
watson_pillow2 小时前
c++ 协程的初步理解
开发语言·c++
庞轩px2 小时前
深入理解 sleep() 与 wait():从基础到监视器队列
java·开发语言·线程··wait·sleep·监视器
Thomas.Sir2 小时前
第二章:LlamaIndex 的基本概念
人工智能·python·ai·llama·llamaindex
故事和你913 小时前
洛谷-算法1-2-排序2
开发语言·数据结构·c++·算法·动态规划·图论
m0_694845573 小时前
Dify部署教程:从AI原型到生产系统的一站式方案
服务器·人工智能·python·数据分析·开源
白毛大侠4 小时前
理解 Go 接口:eface 与 iface 的区别及动态性解析
开发语言·网络·golang
李昊哲小课4 小时前
Python办公自动化教程 - 第7章 综合实战案例 - 企业销售管理系统
开发语言·python·数据分析·excel·数据可视化·openpyxl
Hou'4 小时前
从0到1的C语言传奇之路
c语言·开发语言