利用python添加表格到PowerPoint中的代码示例

 更新时间:2024年08月05日 09:52:45   作者:Eiceblue  
有效的信息传达是演示文稿中的重点,而PowerPoint演示文稿作为最广泛使用的演示工具之一,提供了丰富的功能来帮助演讲者实现这一目标,本文将介绍如何利用Python来添加表格到PowerPoint演示文稿中,需要的朋友可以参考下

前言

有效的信息传达是演示文稿中的重点,而PowerPoint演示文稿作为最广泛使用的演示工具之一,提供了丰富的功能来帮助演讲者实现这一目标。其中,在演示文稿中插入表格可以帮助观众更直观地理解数据和比较信息。通过使用Python这样的强大编程语言,我们可以自动化创建表格,将表格插入到PowerPoint中,从而确保数据的准确性并简化工作流程。本文将介绍如何利用Python来添加表格到PowerPoint演示文稿中。

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

用Python在PowerPoint演示文稿中创建表格

ISlide.Shapes.AppendTable(x: float, y: float, widths: list[float], heights: list[float])方法可以直接在演示文稿的指定幻灯片中创建表格。使用这个方法时,我们需先确定表格的起始坐标,并根据数据计算出各个行高和列宽。
以下步骤演示读取CSV数据并根据数据在演示文稿中创建表格,以及进行简单的表格格式设置:

  1. 导入所需模块。
  2. 创建Presentation对象。
  3. 读取CSV文件数据为二维字符串列表。
  4. 使用Presentation.SlideSize.Type方法设置幻灯片尺寸。
  5. 使用Presentation.Slides.get_Item()方法获取幻灯片。
  6. 计算表格坐标和宽高。
  7. 使用ISlide.Shapes.AppendTable()方法在幻灯片中创建指定大小和位置的表格。
  8. 进行单元格格式设置。
  9. 使用ITable.StylePreset设置表格样式。
  10. 使用Presentation.SaveToFile()方法保存演示文稿。
  11. 释放资源。

代码示例

from spire.presentation import Presentation, TextAlignmentType, TableStylePreset, FileFormat, TextFont, SlideSizeType
import csv

# 创建Presentation对象
presentation = Presentation()

# 设置幻灯片大小
presentation.SlideSize.Type = SlideSizeType.Screen16x9

# 获取默认幻灯片
slide = presentation.Slides.get_Item(0)

# 读取CSV文件数据为二维字符串列表
with open("Sample.csv", "r", encoding="utf-8") as f:
    csv_reader = csv.reader(f)
    data = list(csv_reader)

# 计算表格坐标和宽高
rows = len(data)
columns = len(data[0])
width = float((presentation.SlideSize.Size.Width - 100) / columns)
height = float((presentation.SlideSize.Size.Height - 300) / rows)
widths = [width for _ in range(columns)]
heights = [height for _ in range(rows)]

# 添加表格
table = slide.Shapes.AppendTable(50, 200, widths, heights)
for i in range(rows):
    for j in range(columns):
        table.get_Item(j, i).TextFrame.Text = data[i][j]
        table.get_Item(j, i).TextFrame.Paragraphs.get_Item(0).FirstTextRange.LatinFont = TextFont("微软雅黑")
        table.get_Item(j, i).TextFrame.TextRange.FontHeight = 24

# 设置表头对其居中
for i in range(columns):
    table.get_Item(i, 0).TextFrame.Paragraphs.get_Item(0).Alignment = TextAlignmentType.Center

# 设置表格样式
table.StylePreset = TableStylePreset.ThemedStyle1Accent1

# 保存演示文稿
presentation.SaveToFile("output/插入CSV表格到演示文稿.pptx", FileFormat.Pptx2013)
presentation.Dispose()

添加的表格

本文演示了如何在PowerPoint演示文稿中添加特定数据的表格。

到此这篇关于利用python添加表格到PowerPoint中的代码示例的文章就介绍到这了,更多相关python添加表格到PowerPoint内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python Numpy计算各类距离的方法

    Python Numpy计算各类距离的方法

    这篇文章主要介绍了Python Numpy计算各类距离的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • Python实现获取带合并单元格的表格数据

    Python实现获取带合并单元格的表格数据

    由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,所以本文我们就来聊聊如何使用Python实现获取带合并单元格的表格数据吧
    2025-05-05
  • Python深度学习理解pytorch神经网络批量归一化

    Python深度学习理解pytorch神经网络批量归一化

    这篇文章主要是Python深度学习篇,通过示例的详解让大家更好的理解pytorch神经网络批量归一化,有需要的的朋友可以借鉴参考下,希望能够有所帮助
    2021-10-10
  • 详解tensorflow实现迁移学习实例

    详解tensorflow实现迁移学习实例

    本篇文章主要介绍了详解tensorflow实现迁移学习实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-02-02
  • 用Python将一个列表分割成小列表的实例讲解

    用Python将一个列表分割成小列表的实例讲解

    今天小编就为大家分享一篇用Python将一个列表分割成小列表的实例讲解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-07-07
  • Python中使用Boolean操作符做真值测试实例

    Python中使用Boolean操作符做真值测试实例

    这篇文章主要介绍了Python中使用Boolean操作符做真值测试实例,在Python中,任何类型的对象都可以做真值测试,并且保证返回True或者False,需要的朋友可以参考下
    2015-01-01
  • 利用python打开摄像头及颜色检测方法

    利用python打开摄像头及颜色检测方法

    今天小编就为大家分享一篇利用python打开摄像头及颜色检测方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-08-08
  • linux环境下Django的安装配置详解

    linux环境下Django的安装配置详解

    这篇文章主要介绍了linux环境下Django的安装配置详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-07-07
  • python实现简单名片管理系统

    python实现简单名片管理系统

    这篇文章主要为大家详细介绍了python实现简单名片管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-11-11
  • Python pip安装库时存在缓存以及清除方法

    Python pip安装库时存在缓存以及清除方法

    这篇文章主要给大家介绍了关于Python pip安装库时存在缓存以及清除方法的相关资料,我们在安装Python库时,是安装版的话一般都通过 pip install xxx 来安装包,但安装下载的文件都会缓存下来,而且一般都在C盘,需要的朋友可以参考下
    2023-08-08

最新评论