通过Python在Excel中添加或删除图片的操作流程

 更新时间:2025年12月21日 13:52:14   作者:咕白m625  
在数据处理与办公自动化场景中,Excel 文件常需嵌入图片以增强可视化表达,然而,手动添加或删除图片不仅效率低下,还容易出错,所以本文将系统介绍如何通过 Python 代码,在 Excel 文件中添加图片和删除图片,需要的朋友可以参考下

引言

在数据处理与办公自动化场景中,Excel 文件常需嵌入图片以增强可视化表达。然而,手动添加或删除图片不仅效率低下,还容易出错。如何用 Python 实现 Excel 中图片的自动化管理?答案是:使用 Free Spire.XLS for Python 免费库。

本文将系统介绍如何通过 Python 代码,在 Excel 文件中添加图片删除图片,并提供完整示例与操作流程。内容基于真实可用的技术方案,适用于数据分析师、自动化工程师及办公自动化爱好者。

为什么选择 Python + Free Spire.XLS?

在众多 Python 库中,如 pandasopenpyxl 等,虽然能处理 Excel 表格结构,但对图片操作支持有限。例如:

  • openpyxl 只能读写单元格内容,无法直接操作图片。
  • xlwings 虽可调用 Excel 界面,但依赖运行环境,不适用于脚本自动化。

相比之下,Free Spire.XLS for Python 是一款专为处理 Excel 文件设计的跨平台库,支持图片的添加、删除、裁剪、格式调整等完整功能,且无需安装 Excel,无需依赖 COM 接口,完全在 Python 环境中运行。

✅ 优势总结如下:

对比维度Free Spire.XLS for Pythonopenpyxl / xlwings
图片添加支持✅ 支持❌ 仅支持单元格内容
图片删除支持✅ 支持❌ 无直接接口
无需 Excel 运行✅ 支持❌ 需Excel环境
脚本自动化✅ 高效⚠️ 依赖外部环境

说明:Free Spire.XLS for Python 支持 .xlsx 和 .xls 格式,但有篇幅限制,适用于小型文档。

Python 添加图片到 Excel 中的完整流程

步骤1:安装库

pip install spire.xls.free

步骤2:代码示例 — 将图片添加到指定单元格位置

该场景适用于图片需与单元格内容对齐的情况(如报表中图片对应某行数据),核心是通过 Worksheet.Pictures.Add() 指定图片路径和目标单元格。

from spire.xls import *
from spire.xls.common import *
     
# 创建工作簿对象
workbook = Workbook()

# 获取第一个工作表
sheet = workbook.Worksheets[0]

# 添加图片到工作表指定单元格
imgPath = "logo.png"
picture = sheet.Pictures.Add(1, 3, imgPath)

# 调整单元格大小以容纳图片
sheet.Columns[2].ColumnWidth = 25
sheet.Rows[0].RowHeight = 135

# 保存文件
workbook.SaveToFile("InsertImage.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

扩展技能:自定义图片位置和尺寸添加

若需精确控制图片的坐标和宽高,可通过 ExcelPicture 提供的 LeftColumnOffset / TopRowOffset / Width / Height 属性设置:

from spire.xls import *
from spire.xls.common import *

# 创建工作簿对象
workbook = Workbook()

# 获取第一个工作表
sheet = workbook.Worksheets[0]

# 添加图片到工作表指定单元格
imgPath = "logo.png"
picture = sheet.Pictures.Add(1, 3, imgPath)

# 自定义图片位置
picture.LeftColumnOffset = 90 # 左侧偏移90
picture.TopRowOffset = 20 # 顶部偏移20

# 自定义图片尺寸
picture.Width = 150
picture.Height = 150

# 保存文件
workbook.SaveToFile("add_custom_size_image.xlsx", ExcelVersion.Version2016)
workbook.Dispose()

通过 Python 删除 Excel 中图片的实现方法

Free Spire.XLS for Python 支持按索引删除指定图片或批量删除所有图片,以下是具体实现。

场景 1:删除指定位置的图片

工作表中的图片以列表形式存储在 Pictures 属性中,可通过索引(从 0 开始)定位并删除:

from spire.xls import *
from spire.xls.common import *

# 加载 Excel 文件
workbook = Workbook()
workbook.LoadFromFile("InsertImage.xlsx")

# 获取第一个工作表
sheet = workbook.Worksheets[0]

# 删除工作表中第一张图片
sheet.Pictures[0].Remove()

# 保存文件
workbook.SaveToFile("DeleteImage.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

删除工作表中所有图片

通过遍历 Pictures 列表,批量删除所有图片:

from spire.xls import *
from spire.xls.common import *

# 加载 Excel 文件
workbook = Workbook()
workbook.LoadFromFile("InsertImage.xlsx")

# 获取第一个工作表
sheet = workbook.Worksheets[0]

# 删除工作表中所有图片
for i in range(sheet.Pictures.Count - 1, -1, -1):
    sheet.Pictures[i].Remove()

# 保存文件
workbook.SaveToFile("DeleteAllImage.xlsx", ExcelVersion.Version2013)
workbook.Dispose()

提示:删除后,单元格将恢复为纯文本或空白。

实际应用场景与建议

场景推荐操作
数据报告生成自动添加图表或截图
项目进度可视化在任务表中嵌入进度图
采购单/合同文件处理添加公司 Logo 或审批页图片
自动化审计流程删除旧版本中的冗余图片

Free Spire.XLS for Python 为 Python 开发者提供了轻量、免费的 Excel 图片操作方案,无需依赖 Microsoft Excel 即可完成图片的添加(指定单元格 / 自定义尺寸)和删除(指定图片 / 批量删除)。其优势在于跨平台兼容性和简洁的 API 设计,在实际应用中,可结合批量文件遍历等逻辑,进一步扩展功能,提升 Excel 处理的自动化效率。

以上就是通过Python在Excel中添加或删除图片的操作流程的详细内容,更多关于Python Excel添加或删除图片的资料请关注脚本之家其它相关文章!

相关文章

  • django定期执行任务(实例讲解)

    django定期执行任务(实例讲解)

    下面小编就为大家带来一篇django定期执行任务(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • Python探索之修改Python搜索路径

    Python探索之修改Python搜索路径

    这篇文章主要介绍了Python探索之修改Python搜索路径,具有一定参考价值,需要的朋友可以了解下。
    2017-10-10
  • Django rstful登陆认证并检查session是否过期代码实例

    Django rstful登陆认证并检查session是否过期代码实例

    这篇文章主要介绍了Django rstful登陆认证并检查session是否过期代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • 利用Python实现好看的水波特效

    利用Python实现好看的水波特效

    这篇文章主要介绍了如何利用Python语言实现水波特效,文中的示例代码讲解详细,对我们学习Python有一定的帮助,需要的可以参考一下
    2022-04-04
  • Python 用三行代码提取PDF表格数据

    Python 用三行代码提取PDF表格数据

    这篇文章主要介绍了Python 用三行代码提取PDF表格数据,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • Python面试之os.system()和os.popen()的区别详析

    Python面试之os.system()和os.popen()的区别详析

    Python调用Shell,有两种方法:os.system(cmd)或os.popen(cmd)脚本执行过程中的输出内容,下面这篇文章主要给大家介绍了关于Python面试之os.system()和os.popen()区别的相关资料,需要的朋友可以参考下
    2022-06-06
  • Python利用PIL实现多张图片合成gif动画的案例详解

    Python利用PIL实现多张图片合成gif动画的案例详解

    这篇文章主要介绍了Python利用PIL实现多张图片合成gif动画的案例,文章通过代码示例介绍的非常详细,对大家的学习或工作有一定的帮助,感兴趣的小伙伴可以自己动手试一下
    2023-11-11
  • Python+Selenium实现自动填写问卷

    Python+Selenium实现自动填写问卷

    这篇文章主要介绍了如何利用Python Selenium实现自动填写问卷功能,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2022-03-03
  • 简单了解python关系(比较)运算符

    简单了解python关系(比较)运算符

    这篇文章主要介绍了简单了解python关系(比较)运算符,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-07-07
  • Python求一批字符串的最长公共前缀算法示例

    Python求一批字符串的最长公共前缀算法示例

    这篇文章主要介绍了Python求一批字符串的最长公共前缀算法,涉及Python针对字符串的遍历、判断、计算等相关操作技巧,需要的朋友可以参考下
    2019-03-03

最新评论