【openpyxl-驯化】一文搞懂python是如何将文本、图片写入到execl中的技巧

news2025/1/11 11:13:54

【openpyxl-驯化】一文搞懂python是如何将文本、图片写入到execl中的技巧
 
本次修炼方法请往下查看
在这里插入图片描述

🌈 欢迎莅临我的个人主页 👈这里是我工作、学习、实践 IT领域、真诚分享 踩坑集合,智慧小天地!
🎇 相关内容文档获取 微信公众号
🎇 相关内容视频讲解 B站

🎓 博主简介:AI算法驯化师,混迹多个大厂搜索、推荐、广告、数据分析、数据挖掘岗位 个人申请专利40+,熟练掌握机器、深度学习等各类应用算法原理和项目实战经验

🔧 技术专长: 在机器学习、搜索、广告、推荐、CV、NLP、多模态、数据分析等算法相关领域有丰富的项目实战经验。已累计为求职、科研、学习等需求提供近千次有偿|无偿定制化服务,助力多位小伙伴在学习、求职、工作上少走弯路、提高效率,近一年好评率100%

📝 博客风采: 积极分享关于机器学习、深度学习、数据分析、NLP、PyTorch、Python、Linux、工作、项目总结相关的实用内容。

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

🌵文章目录🌵

    • 🎯 1.基本介绍
    • 💡 2. 代码用法
      • 2.1 安装 openpyxl
      • 2.2 创建工作簿和工作表
      • 2.3 准备数据
      • 2.4 遍历数据并插入文本和图片
    • 💡 3. 高级用法
      • 3.1 调整图片大小和位置
    • 💡 4. 注意事项
    • 💡 5. 总结

下滑查看解决方法

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

  

🎯 1.基本介绍

  我们在进行图片的分类等处理过程中,经常需要将图片插入到execl中,并对其进行显示,这个时候我们需要用到openpyxl库来对其进行处理,openpyxl 是一个 Python 库,用于读写 Excel 2010 xlsx/xlsm/xltx/xltm 文件。它提供了丰富的功能,包括创建工作簿、操作工作表、添加图片等。本文将介绍如何使用 openpyxl 在 Excel 工作表中插入文本和图片。

💡 2. 代码用法

2.1 安装 openpyxl

  首先,确保安装了 openpyxl 库。如果尚未安装,可以通过以下命令安装:,具体的操作如下:

pip install openpyxl

2.2 创建工作簿和工作表

  在插入图片数据之前,我们需要初始化一个execl的类,具体的代码如下所示:

from openpyxl import Workbook
from openpyxl.drawing.image import Image
import os

# 创建一个新的工作簿
wb = Workbook()

# 选择活动工作表
ws = wb.active

2.3 准备数据

  为了使得大家更加清晰的理解,我们构造相关的图片和文本的数据对,具体的代码如下所示:

# 假设你的数据是以下形式的列表,其中每个元素是一个包含文本和图片路径的元组
data = [
    ("文本1", "path/to/image1.png"),
    ("文本2", "path/to/image2.png"),
    # ... 更多数据
]

2.4 遍历数据并插入文本和图片

  接着我们遍历文本图片对并将其写入到对应的格子中,具体的代码如下所示:

# 遍历数据,写入文本和图片
for index, (text, image_path) in enumerate(data, start=1):
    # 写入文本到第一列
    ws.cell(row=index, column=1).value = text
    
    # 确保图片文件存在
    if os.path.exists(image_path):
        # 将图片添加到工作表中,放在第二列
        img = Image(image_path)
        # 计算图片的放置位置,这里假设放在B列
        ws.add_image(img, f'B{index}')
 # 保存工作簿到文件
wb.save("example.xlsx")

💡 3. 高级用法

3.1 调整图片大小和位置

  可以通过 img.width 和 img.height 属性调整图片大小,并通过 ws.add_image 方法的 cell 参数调整图片位置,这样可以使得图片在execl中显示的更加的美观,具体的代码如下所示:

#设置图片的大小
   img.width, img.height = (350, 350)
   # 设置表格的宽20和高85
   ws.column_dimensions["B"].width = 60
   ws.row_dimensions[index].height = 300
   # 图片插入名称对应单元格

💡 4. 注意事项

  • 确保图片路径正确,且图片文件存在于给定路径。
  • openpyxl 支持插入多种格式的图片,包括 PNG、JPEG 等。
  • 在调整图片大小时,注意保持图片的宽高比,以避免图片变形。

💡 5. 总结

  openpyxl 是一个功能强大的库,用于操作 Excel 文件。通过本博客的代码示例,我们学习了如何使用 openpyxl 在 Excel 中插入文本和图片。这些技术可以用于生成报告、制作图表或其他需要将文本和图片结合展示的场景。希望这篇博客能够帮助你更好地利用 openpyxl 进行 Excel 操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2081782.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

TikTok/Shopee本土多站点涨佣金,卖家如何应对?EasyBoss ERP总结了5大应对策

近日消息,TikTok Shop马来西亚本土店将调整其市场佣金费用与交易费用,并为参与Mall计划的卖家引入Mall佣金费用,新的费率将从2024年9月5日生效。 TikTok Shop马来站佣金费率调整规则 图源:TikTok Shop 注:上述佣金率仅…

Linux中的常见命令——时间日期类命令

1、date显示当前时间 基本语法 写法功能描述date显示当前时间date %Y显示当前年份【四位数】date %m显示当前月份date %d显示当前是哪一天date "%Y-%m-%d %H:%M:%S" 显示年月日时分秒 【由于年月日和时分秒中间有空格所以需要用引号引起来】 实操案例 1、显示当…

Salesforce篇——如何在lightning页面添加ListviewButton使用lwc组件

1.创建lwc组件&#xff0c;用于展示listview已选数据&#xff1a; html&#xff1a; <template><lightning-card title"Selected Records"><p>Selected Record IDs: {selectedIds}</p><lightning-button label"返回" onclick…

想避免踩雷选到好用的骨传导耳机?精选热门五款分享

目前在市面当中&#xff0c;骨传导耳机被称之为是黑科技耳机&#xff0c;骨传导耳机拥有很多优势&#xff0c;在听歌时不需要入耳&#xff0c;不会伤耳朵。随着骨传导耳机品牌的不断发展&#xff0c;人们在选购骨传导耳机时&#xff0c;也会觉得非常困难&#xff0c;可能一不小…

Selenium的四种部署方式详解

关于selenium 的部署&#xff0c;我在网上找了很多&#xff0c;基本上都没有提到或是说的比较清晰的。当时我一直有个困惑&#xff1a;测试的脚本代码&#xff0c;是放在跟浏览器同一台机器上呢&#xff0c;还是放在Application Server上&#xff1f; 在官方开发文档中&#x…

人工智能项目管理︱大模型在项目管理中的应用

全国项目经理专业人士年度盛会 河钢数字技术股份有限公司绿色低碳事业部研发交付中心部门经理江鑫先生受邀为PMO评论主办的全国项目经理专业人士年度盛会——2024第四届中国项目经理大会演讲嘉宾&#xff0c;演讲议题为“大模型在项目管理中的应用”。大会将于10月26-27日在北京…

使用终端工具Tabby(跳板机)连接ssh

目录 1.tabby下载2.下载安装3.安装成功3.1在应用中配置语言为中文3.2外观可以更改字体大小颜色等3.3配色方案改变外观颜色3.4快捷键&#xff0c;可以根据自己的习惯自定义修改3.5配置和连接&#xff08;最重要的&#xff0c;安装完成要连接ssh可以直接到这一步&#xff09; 1.t…

【运维心得】获取程控交换机的IP的笨办法

本文主要解决了当你忘记某个程控交换机设备的IP地址的时候&#xff0c;如何通过技术手段进行获取。 背景 智能手机的普及&#xff0c;让固定电话已经逐渐从寻常百姓家里消失了。但仍然是单位客户的必要选择&#xff0c;例如400或者800电话&#xff0c;当然&#xff0c;也有公…

共轴麦轮直立、运动、位置串级PID

角度PID 微分项Angle_Pram[KD] * gyroy&#xff1a;根据角速度的变化率来调整电机PWM&#xff0c;角速度变化越快&#xff0c;调整的幅度也越大。 速度PID Encoder_Least (Encoder1 Encoder2 Encoder3 Encoder4) - Trg_Speed;&#xff1a;计算速度偏差&#xff0c;即四个编…

大批量影像瓦片优化

背景 在很多场景中&#xff0c;需要用的影像瓦片&#xff0c;常规的思路是将tif进行切图&#xff0c;做成分层的瓦片&#xff1a; 但是&#xff0c;如果层级太高&#xff0c;产生的文件将十分庞大&#xff0c;据测试&#xff0c;某地级市18层级切片&#xff0c;内存占用高达2…

【Windows】bat批处理获取文件路径,并写入注册表

echo off setlocal:: 获取当前绝对路径 for %%I in ("%~dp0") do set "CURRENT_DIR%%~fI":: 拼接文件名 set "FILE_NAMEtest.exe" set "FULL_PATH%CURRENT_DIR%%FILE_NAME%"::创建注册表项并写入数据 ::/v 具体的注册表项值的查…

图片拼图怎么操作?教你5个快速拼图的方法

我的元气假期已经到尾声了&#xff0c;在此期间的照片也积累了很多&#xff0c;要怎么把它们全部分享出来呢&#xff1f; 当然&#xff0c;最直接的方式就是把它们做成一张张精美的图片拼图啦&#xff01;这样不仅能节省空间&#xff0c;还能让朋友们一眼就看到你的精彩假期生…

一篇文章带你入门Golang

Go语言的特点和优势 1&#xff0e;简单易学 Go语言语法简单&#xff0c;包含了类似C语言的语法。如果读者已经掌握了两到三门编程语言&#xff0c;那么学习Go语言只需要几天的熟悉过程。即使一名刚入门的开发者&#xff0c;花几个星期也能写出来性能较高的程序。 2&#xff…

GlobalUsing、JSON Schema、NuGet使用方法

一、速通一图流 二、GlobalUsing 使用 1. 关于 GlobalUsing 在 .NET 6/C# 10 之后&#xff0c;微软引入了 GlobalUsings 机制。这个机制允许你在项目根目录下创建一个 GlobalUsings.cs 文件&#xff0c;并在其中定义全局的 using 指令。这样一来&#xff0c;项目中的其他 .cs…

公网、内网ip地址专用SSL证书

现在给网站安装SSL证书来实现网站的HTTPS安全访问已经成了大多数人的共识&#xff0c;但是有一些特殊情况&#xff1a;比如对于个别的应用IP地址不需要绑定域名&#xff0c;只是单纯用IP来访问网站&#xff0c;这种情况下&#xff0c;可以实现HTTPS访问吗&#xff1f; 先说答案…

通风天窗设计使用说明

通风天窗设计使用说明旨在为用户提供一套全面、详细的安装、使用、维护及安全指南&#xff0c;适用于各类工业厂房、仓库、体育馆等大型公共建筑顶部的自然通风系统。通风天窗通过有效利用风压和热压效应&#xff0c;促进室内空气流通降低室内温度&#xff0c;改善工作环境&…

【Python基础】基础语法

本文收录于 《Python编程入门》专栏&#xff0c;从零基础开始&#xff0c;分享一些Python编程基础知识&#xff0c;欢迎关注&#xff0c;谢谢&#xff01; 文章目录 一、前言二、Python 基础语法2.1 编码格式2.2 标识符2.3 保留字2.4 注释2.5 行与缩进2.6 多行语句2.7 同一行显…

USB5834数据采集卡30路模拟量采集卡DAQ卡——阿尔泰科技

概述&#xff1a; 产品应用&#xff1a; AD模拟量输入功能&#xff1a; DI数字量输入功能&#xff1a; DO数字量输出功能&#xff1a; CNT定时/计数器功能&#xff1a; 其它指标&#xff1a; 板卡图片及尺寸&#xff1a;

等保需要的设备部署vs网络安全域划分原则

等保需要的安全设备和部署 技术要点–等保2级 技术要点–等保3级 安全产品/服务全景图 选型产品说明 安全区域边界配置 资产探测及漏洞检测配置 网络安全域划分原则 网络安全域 定义 网络安全域是一种网络划分方式&#xff0c;将具有相同安全需求、访问控制、相同信任级别、…

uva227 (我tm破防了!!!)

本人写了小十天就干这个&#xff08;我太菜了那个紫皮书出这么恶心的题本身代码逻辑并不难&#xff0c;我也写出来了但是就算有问题我ccccccccccccccc&#xff09; 首先说一下我不讲这个&#xff0c;因为我本身vs没有运行出来正确结果&#xff0c;在第二个输入中我输入的这个多…