用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

相关推荐
数据智能老司机10 小时前
精通 Python 设计模式——分布式系统模式
python·设计模式·架构
数据智能老司机11 小时前
精通 Python 设计模式——并发与异步模式
python·设计模式·编程语言
数据智能老司机11 小时前
精通 Python 设计模式——测试模式
python·设计模式·架构
数据智能老司机11 小时前
精通 Python 设计模式——性能模式
python·设计模式·架构
c8i11 小时前
drf初步梳理
python·django
每日AI新事件11 小时前
python的异步函数
python
这里有鱼汤12 小时前
miniQMT下载历史行情数据太慢怎么办?一招提速10倍!
前端·python
databook1 天前
Manim实现脉冲闪烁特效
后端·python·动效
程序设计实验室1 天前
2025年了,在 Django 之外,Python Web 框架还能怎么选?
python
倔强青铜三1 天前
苦练Python第46天:文件写入与上下文管理器
人工智能·python·面试