Python3,区区10行代码,批量把图片插入Excel指定单元格中,省下时间去烫头发。

简介: Python3,区区10行代码,批量把图片插入Excel指定单元格中,省下时间去烫头发。

1、引言

小屌丝:鱼哥, 想请教你个问题。

小鱼:啥问题呢?

小屌丝:我想把图片插入到excel里面

小鱼:这个还用问我? 你是昨晚喝多了?

小屌丝:不是的,我是想把图片插入到excel单元格里面

小鱼:这么简单的操作,你竟然也说得出口!

小屌丝:不是的,我是想批量插入图片

小鱼:excel不支持批量插入图片功能??

小屌丝:是的,我想把图片批量按照名称和统一尺寸,放入到单元格里面

小鱼:昂… 这个 excel也能批量操作啊。

小屌丝:太费劲了, 我有100多张图片, 我还得手动调单元格的大小,

小鱼:那确实挺多的, 那你就慢慢搞一下了,闲着也是闲着…

小屌丝:鱼哥,别啊,节省的时间,去泡个澡,剪个头发,不舒服吗?

小鱼:也对,不过现在剪头发都是198了…

小屌丝:没事鱼哥, 我有券…

小鱼:那… 等我会啊…

2、代码实战

2.1 代码示例

代码示例

# -*- coding: utf-8 -*-
# @Time   : 2022-12-05
# @Author : Carl_DJ
'''
实现功能:
    在excel中,对应的名称后面,插入图片
'''
import openpyxl,PIL
from openpyxl.drawing.image import Image
import os
#excel文件路径
excel_path = './pic/image.xlsx'
#图片名称为A列
img_name_column = 'A'
#图片写入B列
img_column = 'B'
#读取图片的地址
img_path = './data/picture'
#转换图片格式,强制转换成jpg格式
# img_type = PIL.Image.open(img_path).convert("RGB")
# img_type.save(img_path, 'jpeg')
#打开excel文件
wb = openpyxl.load_workbook(excel_path)
#获取sheet页
ws = wb.active
for i, v in enumerate(ws[img_name_column], start=1):
    #图片路径
    img_file_path = os.path.join(img_path, f"{v.value}.jpg")
    #获取图片
    img = Image(img_file_path)
    #设置图片的大小
    img.width, img.height = (110, 110)
    # 设置表格的宽20和高85
    ws.column_dimensions[img_column].width = 20
    ws.row_dimensions[i].height = 85
    # 图片插入名称对应单元格
    ws.add_image(img, anchor=img_column + str(i))
#保存
wb.save(excel_path)  # 保存
#关闭
wb.close()
print(f'保存完成')

运行结果

2.2 遇到问题及处理方案

2.2.1 遇到问题

这里,小鱼在运行脚本时, 遇到一个错误提示,

图片的类型是 “.webp”,如下:

我首先看图片的后缀,是不是.webp,发现,已修改为.jpg

于是,小鱼就想到了,是不是下载图片的时候, 虽然图片的后缀改成.jpg,但是,图片的本质,还是**.webp**格式,

为了验证小鱼的猜想,我就重新下载一次百度图片,如下:

确实,是这样的。

2.2.2 解决方案

遇到这种问题,两种解决方案:

1、直接下载jgp格式的图片;

可以参照小鱼的这篇《Python3,5行代码,让你拥有无限量壁纸美图》 ,这样下载的都是jpg格式的图片。

2、代码强制转换:

强制转换图片格式:

#转换图片格式,强制转换成jpeg格式
img_type = PIL.Image.open(img_path).convert("RGB")
img_type.save(img_path, 'jpeg')

3、总结

看到这里,今天的分享就差不多结束了。

在2022年初的时候, 小鱼把图片写入到excel里面,得到的反馈很不错。

我是小鱼

  • 51 认证讲师;
  • 企业金牌面试官;

关注我,带你学习更多更有趣的Python知识。

目录
相关文章
|
7天前
|
文字识别 BI
【图片型PDF】批量识别扫描件PDF指定区域局部位置内容,将识别内容导出Excel表格或批量改名文件,基于阿里云OCR对图片型PDF识别改名案例实现
在医疗和政务等领域,图片型PDF文件(如病历、报告、公文扫描件)的处理需求广泛。通过OCR技术识别这些文件中的文字信息,提取关键内容并保存为表格,极大提高了信息管理和利用效率。本文介绍一款工具——咕嘎批量OCR系统,帮助用户快速处理图片型PDF文件,支持区域识别、内容提取、导出表格及批量改名等功能。下载工具后,按步骤选择处理模式、进行区域采样、批量处理文件,几分钟内即可高效完成数百个文件的处理。
49 8
|
1月前
|
数据可视化 数据挖掘 大数据
1.1 学习Python操作Excel的必要性
学习Python操作Excel在当今数据驱动的商业环境中至关重要。Python能处理大规模数据集,突破Excel行数限制;提供丰富的库实现复杂数据分析和自动化任务,显著提高效率。掌握这项技能不仅能提升个人能力,还能为企业带来价值,减少人为错误,提高决策效率。推荐从基础语法、Excel操作库开始学习,逐步进阶到数据可视化和自动化报表系统。通过实际项目巩固知识,关注新技术,为职业发展奠定坚实基础。
|
2月前
|
Python
使用OpenPyXL库实现Excel单元格其他对齐方式设置
本文介绍了如何使用Python的`openpyxl`库设置Excel单元格中的文本对齐方式,包括文本旋转、换行、自动调整大小和缩进等,通过具体示例代码展示了每种对齐方式的应用方法,适合需要频繁操作Excel文件的用户学习参考。
187 85
使用OpenPyXL库实现Excel单元格其他对齐方式设置
|
2月前
|
机器学习/深度学习 前端开发 数据处理
利用Python将Excel快速转换成HTML
本文介绍如何使用Python将Excel文件快速转换成HTML格式,以便在网页上展示或进行进一步的数据处理。通过pandas库,你可以轻松读取Excel文件并将其转换为HTML表格,最后保存为HTML文件。文中提供了详细的代码示例和注意事项,帮助你顺利完成这一任务。
105 0
|
2月前
|
数据采集 数据可视化 数据挖掘
利用Python自动化处理Excel数据:从基础到进阶####
本文旨在为读者提供一个全面的指南,通过Python编程语言实现Excel数据的自动化处理。无论你是初学者还是有经验的开发者,本文都将帮助你掌握Pandas和openpyxl这两个强大的库,从而提升数据处理的效率和准确性。我们将从环境设置开始,逐步深入到数据读取、清洗、分析和可视化等各个环节,最终实现一个实际的自动化项目案例。 ####
305 10
|
3月前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
190 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
4月前
|
Python
python读写操作excel日志
主要是读写操作,创建表格
83 2
|
9月前
|
Python
补充python操作excel示例xlwings常用函数
补充python操作excel示例xlwings常用函数
182 0
|
9月前
|
存储 数据处理 索引
Python操作Excel常用方法汇总
Python操作Excel常用方法汇总
288 0
|
数据采集 数据可视化 Python
Python操作excel写入读取数据,简单实用
Python操作excel写入读取数据,简单实用

热门文章

最新文章

推荐镜像

更多