使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

2025-04-24 05:50

本文主要是介绍使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了...

一、引言

PPT是一种高效的信息展示工具,广泛应用于教育、商务js和设计等多个领域。PPT文档中常常包含丰富的图片内容,这些图片不仅提升了视觉效果,也增强了信息的传递效率。将这些图片从PPT中提取出javascript来,可以再次用于其他文档、宣传册、网站或社交媒体内容中。

本文将介绍如何使用 Python 实现自动化提取 PowerPoint(PPT 或 PPTX)文件中的图片。主要内容包括提取PPT背景图片(幻灯片背景图片和幻灯片模板背景图片)、从幻灯片形状中提取图片,从整个PPT文档中提取图片,以及提取图片的相关信息,如坐标位置、宽度和高度等。

二、环境与工具

在提取 PPT 中的图片之前,需要确保你的计算机上已安装 Python。如果没有安装,可前往 Python 官方网站下载安装。

安装完成后,需要安装 Spire.Presentation for Python 库,该库主要用于生成、操作和转换PPT演示文稿。安装步骤如下:

  • 打开终端
  • 输入以下命令并回车:
pip install spire.presentation

三、Python 提取PPT背景图片

PowerPoint 幻灯片通常包含美观的背景图片,这些图片可能存在于单个幻灯片中,也可能存在于幻灯片母版(模板)中。提取这些背景图片,对于设计师、教育工作者或需要复用素材的用户来说非常有用。

3.1 提取幻灯片背景图片

要提取PPT幻灯片中的背景图片,可通过以下步骤http://www.chinasem.cn来实现:

  • 初始化 Presentation 类的实例,并使用 Presentation.LoadFromFile() 方法加载PPT或PPTX文件。
  • 通过Presentation.Slides集合遍历文件中的幻灯片。
    • 通过 ISlide.SlideBackground.Fill.FillType 属性判断每张幻灯片的背景填充类型是否为图片填充。
      • 若为图片填充,则提取背景图片并保存为图片文件。

实现代码:

from spire.presentation import *
import os
 
def extract_background_images_from_slides(ppt_path, output_folder):
    """从幻灯片中提取背景图片"""
    presentation = Presentation()
    presentation.LoadFromFile(ppt_path)
    os.makedirs(output_folder, exist_ok=True)
 
    for i, slide in enumerate(presentation.Slides):
        bgd = slide.SlideBackground
        if bgd.Fill.FillType == FillFormatType.Picture:
            image_data = bgd.Fill.PictureFill.Picture.EmbedImage
            output_path = os.path.join(output_folder, f"幻灯片背景_{i}.png")
     China编程       image_data.Image.Save(output_path)
 
    presentation.Dispose()
 
# 使用示例
extract_background_images_from_slides("测试.pptx", "图片")

3.2 提取幻灯片母版背景图片

从幻灯片母版中提取背景图片的步骤与以上步骤类似,只是遍历的集合改为Presentation.Masters。具体步骤如下:

  • 初始化 Presentation 类的实例,并使用 Presentation.LoadFromFile() 方法加载PPT或PPTX文件。
  • 通过Presentation.Masters集合遍历文件中的幻灯片母版。
    • 通过IMasterSlide.SlideBackground.Fill.FillType属性判断每个幻灯片母版的背景填充类型是否为图片填充。
      • 若为图片填充,则提取背景图片并保存为图片文件。

实现代码:

from spire.presentation import *
import os
 
def extract_background_images_from_slide_masters(ppt_path, output_folder):
    """从幻灯片母版中提取背景图片"""
    presentation = Presentation()
    presentation.LoadFromFile(ppt_path)
    os.makedirs(output_folder, exist_ok=True)
 
    for i, slide_master in enumerate(presentation.Masters):
        bgd = slide_master.SlideBackground
        if bgd.Fill.FillType == FillFormatType.Picture:
            image_data = bgd.Fill.PictureFill.Picture.EmbedImage
            output_path = os.path.join(output_folder, f"幻灯片母版背景_{i}.png")
            image_data.Image.Save(output_path)
 
    presentation.Dispose()
 
# 使用示例
extract_background_images_from_slide_masters("测试.pptx", "图片")

四、Python 从PPT幻灯片的形状中提取图片

PPT 幻灯片中的图片也可能以形状对象的形式存在,提取步骤如下:

  • 初始化 Presentation 类的实例,并使用 Presentation.LoadFromFile() 方法加载PPT或PPTX文件。
  • 通过Presentation.Slides集合遍历文件中的幻灯片。
  • 通过ISlide.Shapes集合遍历每张幻灯片中的所有形状。
  • 判断形状是否为 PictureShape 或 SlidePicture 对象。
    • 若为PictureShape 或 SlidePicture 对象,则提取图片并保存为图片文件。

实现代码

from spire.presentation import *
import os
 
def extract_images_from_shapes(ppt_path, output_folder):
    """从幻灯片形状中提取图片"""
    presentation = Presentation()
    presentation.LoadFromFile(ppt_path)
    os.makedirs(output_folder, exist_ok=True)
 
    img_count = 0
 
    for slide_index, slide in enumerate(presentation.Slides):
        for shape_index, shape in enumerate(slide.Shapes):
            if isinstance(shape, PictureShape):
                image_data = shape.EmbedImage
            elif isinstance(shape, SlidePicture):
                image_data = shape.PictureFill.Picture.EmbedImage
            else:
                continue
 
            img_count += 1
            output_path = os.path.join(output_folder, f"图片_{img_count}.png")
            image_data.Image.Save(output_path)
 
    presentation.Dispose()

五、Python 提取PPT中的图片信息(如坐标、宽度和高度等)

在进行 PPT文档分析或自动化处理时,可能需要获取图片的具体信息,例如:

  • 坐标(相对于幻灯片左上角的位置)
  • 尺寸(图片的宽度和高度,单位为磅)

可通过以下编程China编程步骤提取这些信息:

  • 初始化 Presentation 类的实例,并使用 Presentation.LoadFromFile() 方法加载PPT或PPTX文件。
  • 通过Presentation.Slides集合遍历文件中的幻灯片。
  • 通过ISlide.Shapes集合遍历每张幻灯片中的所有形状。
  • 判断形状是否为 PictureShape 或 SlidePicture 对象。
    • 若为PictureShape 或 SlidePicture 对象,则获取当前图片的X/Y坐标、宽度、高度和所在幻灯片等信息。

实现代码

from spire.presentation import *
 
def extract_image_metadata(ppt_path):
    """获取 PPT 中图片的信息(所在幻灯片、坐标位置、宽度与高度等)"""
    presentation = Presentation()
    presentation.LoadFromFile(ppt_path)
 
    for slide_index, slide in enumerate(presentation.Slides):
        for shape_index, shape in enumerate(slide.Shapes):
            if isinstance(shape, PictureShape) or isinstance(shape, SlidePicture):
                x = shape.Frame.Rectangle.X
                y = shape.Frame.Rectangle.Y
                width = shape.Frame.Rectangle.Width
                height = shape.Frame.Rectangle.Height
                print(f"幻灯片 {slide_index + 1},形状 {shape_index + 1}:X={x}, Y={y}, 宽度={width}, 高度={height}")
 
    presentation.Dispose()
 
# 使用示例
extract_image_metadata("测试.pptx")

六、Python 从整个PPT文档中提取图片

如果要从整个PPT文档中提取图片,可遍历 Presentation.Images 集合。具体步骤如下:

  • 初始化 Presentation 类的实例,并使用 Presentation.LoadFromFile() 方法加载PPT或PPTX文件。
  • 使用Presentation.Images 集合遍历PPT文档中的图片。
    • 提取每张图片并保存为图片文件。

实现代码

from spire.presentation import *
import os
 
def extract_images_from_presentation(ppt_path, output_folder):
    """提取整个PPT文档中的图片"""
    presentation = Presentation()
    presentation.LoadFromFile(ppt_path)
    os.makedirs(output_folder, exist_ok=True)
 
    for i, image in enumerate(presentation.Images):
        output_path = os.path.join(output_folder, f"图片_{i}.png")
        image.Image.Save(output_path)
 
    presentation.Dispose()
 
# 使用示例
extract_images_from_presentation("测试.pptx", "图片")

以上就是使用Python从PPT中提取图片和图片信息的全部内容。

到此这篇关于使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)的文章就介绍到这了,更多相关Python提取PPT图片和图片信息内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154346

相关文章

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

Python中的Walrus运算符分析示例详解

《Python中的Walrus运算符分析示例详解》Python中的Walrus运算符(:=)是Python3.8引入的一个新特性,允许在表达式中同时赋值和返回值,它的核心作用是减少重复计算,提升代码简... 目录1. 在循环中避免重复计算2. 在条件判断中同时赋值变量3. 在列表推导式或字典推导式中简化逻辑

python处理带有时区的日期和时间数据

《python处理带有时区的日期和时间数据》这篇文章主要为大家详细介绍了如何在Python中使用pytz库处理时区信息,包括获取当前UTC时间,转换为特定时区等,有需要的小伙伴可以参考一下... 目录时区基本信息python datetime使用timezonepandas处理时区数据知识延展时区基本信息

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地

Java Stream流使用案例深入详解

《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多