用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

相关推荐
rzl021 分钟前
java web5(黑马)
java·开发语言·前端
jingling55514 分钟前
面试版-前端开发核心知识
开发语言·前端·javascript·vue.js·面试·前端框架
阿蒙Amon31 分钟前
【Python小工具】使用 OpenCV 获取视频时长的详细指南
python·opencv·音视频
m0_6873998432 分钟前
写一个Ununtu C++ 程序,调用ffmpeg API, 来判断一个数字电影的视频文件mxf 是不是Jpeg2000?
开发语言·c++·ffmpeg
爱上语文43 分钟前
Redis基础(5):Redis的Java客户端
java·开发语言·数据库·redis·后端
A~taoker1 小时前
taoker的项目维护(ng服务器)
java·开发语言
萧曵 丶1 小时前
Rust 中的返回类型
开发语言·后端·rust
hi星尘1 小时前
深度解析:Java内部类与外部类的交互机制
java·开发语言·交互
看到我,请让我去学习1 小时前
Qt编程-qml操作(js,c++,canvas)
开发语言·qt
橘子编程1 小时前
Python-Word文档、PPT、PDF以及Pillow处理图像详解
开发语言·python