IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> python pandas openpyxl xlsxwriter 读取图片插入特定位置 -> 正文阅读

[Python知识库]python pandas openpyxl xlsxwriter 读取图片插入特定位置

import io
from openpyxl_image_loader import SheetImageLoader
import openpyxl
import pandas as pd
import time

def __insert_photo_mmc(excel_file_name):
    
    #读取图片来源表
    photoExcel = openpyxl.load_workbook(filename)

    # 读取所有图片
    dic_style_image = dict()

    for sheet_name in photoExcel.sheetnames:
        sheet = photoExcel[sheet_name]  # 打开sheet
        image_loader = SheetImageLoader(sheet)
        for i in range(2, sheet.max_row+1):  # 从第2行开始,总行数要+1
            try:
                style = sheet['I'+str(i)].value  # style 在 A列
                style = style.upper()

                image = image_loader.get('A'+str(i))  # 图片在 C列
                dic_style_image[style] = image

            except ValueError:  # 没有图片,或图片超出单元格的情况
                logger.info("idx={} 没有图片".format(i))

    # print(len(dic_style_image))
    # dic_style_image['ARJL100798-BK3'].show()

    #######输出excel#################
    output_file = time.strftime("%d%H%M%S", time.localtime()) + '.xlsx' #输出的表
    writer = pd.ExcelWriter(output_file, engine='xlsxwriter')
    workbook = writer.book

    data_excel = pd.ExcelFile(excel_file_name) #读取要被插入图片的excel表

    for sheet_name in data_excel.sheet_names:
        df = data_excel.parse(sheet_name=sheet_name)
        df.to_excel(writer, sheet_name=sheet_name, index=False)
        sheet = writer.sheets[sheet_name]
        # 设置图片大小
        image_size = (81, 54)

        for idx, row in df.iterrows():
            style = row['款号']
            style = style.upper()
            img = dic_style_image.get(style, None)

            anchor = 'H'+str(idx+2)  # 图片输出在H列

            if img is None:
                sheet.write_string(anchor, 'no photho')
            else:
                img_file_name = img.filename

                # 设置行高
                height = math.ceil(image_size[1]*0.85)
                sheet.set_row(idx+1, height)

                #resize图片
                img = img.resize(image_size)

                #转成byteio格式
                buf = io.BytesIO()
                img.save(buf, format='JPEG')
                sheet.insert_image(anchor, img_file_name, 
                                {'image_data': buf, 'x_offset': 1, 'y_offset': 3})

    workbook.close()
    data_excel.close()

    return output_file

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2022-04-04 12:06:36  更:2022-04-04 12:11:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 18:07:13-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码