python 图片插入excel


from openpyxl import Workbook, load_workbook
from openpyxl.drawing.image import Image
from openpyxl.drawing.spreadsheet_drawing import AnchorMarker, TwoCellAnchor
import numpy as np
import os
from openpyxl.styles import Alignment

def GetImgNameByEveryDir(file_dir,videoProperty):
    FileNameWithPath = []
    FileName = []
    FileDir = []
    for root, dirs, files in os.walk(file_dir):
        for file in files:
            if os.path.splitext(file)[1] in videoProperty:
                FileNameWithPath.append(os.path.join(root, file))  # 保存图片路径
                FileName.append(file)                              # 保存图片名称
                FileDir.append(root + '/')            # 保存图片所在文件夹
    return np.array(FileName), np.array(FileNameWithPath),FileDir

## 循环便利文件
class Generate(object):
    def __init__(self,xls_save_path,file_dir=None):
        self.file_name = xls_save_path
        self.file_dir  = file_dir
        pass
    def save_one_dir_imgs_to_excel(self):
        if os.path.exists(self.file_name)==False:
            wb = Workbook()# 使用openpyxl创建新的workbook
        else:
            wb = load_workbook(filename=self.file_name)

        try:
            ws = wb['Sheet']
            wb.remove(ws)  # 删掉默认的sheet
        except:
            print('默认sheet不存在,不用删除...')
        ws = wb.active
        ff,pp,dd = GetImgNameByEveryDir(self.file_dir,['.jpg'])
        ws = wb.create_sheet('仪表结果')# 根据文件夹名称创建sheet
        alignment_center = Alignment(horizontal='center', vertical='center')
        ws.cell(row=1, column=1, value='结果图片').alignment = alignment_center# 设置第一行的字段
        ws.cell(row=1, column=2, value='图片名称').alignment = alignment_center
        ws.cell(row=1, column=3, value='仪表读数').alignment = alignment_center
        ws.cell(row=1, column=4, value='错误类型').alignment = alignment_center
        
        for kk in range(len(pp)):
            ws.row_dimensions[kk+2].height   = 150
            ws.column_dimensions["A"].width  = 30
            ws.column_dimensions["B"].width  = 60
            ws.column_dimensions["C"].width  = 10
            ws.column_dimensions["D"].width  = 10
            ws.cell(row=kk+2, column=3, value='222222').alignment = alignment_center   # 后面的.alignment是单元格内容居中
            ws.cell(row=kk+2, column=2, value=pp[kk]).alignment   = alignment_center


            img   = Image(pp[kk])# 创建openpyxl的Image对象
            _from = AnchorMarker(0, 50000, kk+1, 50000)# 创建锚标记对象,设置图片所占的row
            to    = AnchorMarker(1, -50000, kk+1+1, -50000)# 创建锚标记对象,设置图片所占的row 从而确认了图片位置
            img.anchor = TwoCellAnchor('twoCell', _from, to)# 将锚标记对象设置图片对象的锚属性,图形就具备了所在位置
            ws.add_image(img)# 添加图片
            


        # print(allfiles)
        wb.save(self.file_name)

    def save_one_result_to_excel(self,resultImgPath,resultMeter,meterErrorType,dir1,dir2):
        if os.path.exists(self.file_name)==False:
            wb = Workbook()# 使用openpyxl创建新的workbook
        else:
            wb = load_workbook(filename=self.file_name)

        try:
            ws = wb['Sheet']
            wb.remove(ws)  # 删掉默认的sheet
        except:
            print('默认sheet不存在,不用删除...')

        sheet_names      = wb.sheetnames
        print('ws sheet  = ',sheet_names)
        ws               = wb.active
        if '仪表结果' not in sheet_names:
            ws           = wb.create_sheet('仪表结果')# 根据文件夹名称创建sheet
        alignment_center = Alignment(horizontal='center', vertical='center')
        rows             = ws.max_row
        columns          = ws.max_column
        resultImgPath2   = resultImgPath.replace('\\', '/')
        imgName          = resultImgPath2.split('/')[-1] # linux用这个

        print('rows = ',rows)
        ws.cell(row = 1, column = 1, value = '结果图片').alignment = alignment_center# 设置第一行的字段
        ws.cell(row = 1, column = 2, value = '图片名称').alignment = alignment_center
        ws.cell(row = 1, column = 3, value = '仪表读数').alignment = alignment_center
        ws.cell(row = 1, column = 4, value = '错误类型').alignment = alignment_center
        
        ws.row_dimensions[rows+1].height = 150
        ws.column_dimensions["A"].width  = 30
        ws.column_dimensions["B"].width  = 10
        ws.column_dimensions["C"].width  = 30
        ws.column_dimensions["D"].width  = 10
        # ws.cell(row = rows + 1, column = 3, value = resultMeter).alignment    = alignment_center   # 后面的.alignment是单元格内容居中
        ws.cell(row = rows + 1, column = 2, value = '').alignment        = alignment_center
        # ws.cell(row = rows + 1, column = 4, value = meterErrorType).alignment = alignment_center
        # ws.cell(row = rows + 1, column = 5, value = meterErrorType).alignment = alignment_center

        try:
            resultImgPath1 = dir1 + '/' + imgName
            img        = Image(resultImgPath1)# 创建openpyxl的Image对象
            _from      = AnchorMarker(0,  50000, rows+0,  50000)# 创建锚标记对象,设置图片所占的row
            to         = AnchorMarker(1, -50000, rows+1, -50000)# 创建锚标记对象,设置图片所占的row 从而确认了图片位置
            img.anchor = TwoCellAnchor('twoCell', _from, to)# 将锚标记对象设置图片对象的锚属性,图形就具备了所在位置
            ws.add_image(img)# 添加图片

            resultImgPath2 = dir2 + '/' + imgName
            img2        = Image(resultImgPath2)# 创建openpyxl的Image对象
            _from2      = AnchorMarker(2,  50000, rows+0,  50000)# 创建锚标记对象,设置图片所占的row
            to2         = AnchorMarker(3, -50000, rows+1, -50000)# 创建锚标记对象,设置图片所占的row 从而确认了图片位置
            img2.anchor = TwoCellAnchor('twoCell', _from2, to2)# 将锚标记对象设置图片对象的锚属性,图形就具备了所在位置
            ws.add_image(img2)# 添加图片
        except:
            print('')


        
        wb.save(self.file_name)

def GetImgNameByEveryDir(file_dir,videoProperty):
    FileNameWithPath = []
    FileName = []
    FileDir = []
    for root, dirs, files in os.walk(file_dir):
        for file in files:
            if os.path.splitext(file)[1] in videoProperty:
                FileNameWithPath.append(os.path.join(root, file))  # 保存图片路径
                FileName.append(file)                              # 保存图片名称
                FileDir.append(root + '/')            # 保存图片所在文件夹
    return np.array(FileName), np.array(FileNameWithPath),FileDir

dir_need1 = '图1文件夹/'       # 原图文件夹
dir_need2 = '图2文件夹/'   # 结果图文件夹
ge=Generate('保存图片到excel.xlsx',dir_need1)
ff,pp,dd = GetImgNameByEveryDir(dir_need1,['.jpg'])
for k in range(len(ff)):
    ge.save_one_result_to_excel(pp[k],'1234','1235',dir_need1,dir_need2)

插入展示如下:

### 回答1: 可以使用Python的openpyxl库来将图片插入Excel中。具体步骤如下: 1. 导入openpyxl库和PIL库(用于处理图片): ```python from openpyxl import Workbook from openpyxl.drawing.image import Image from PIL import Image as PILImage ``` 2. 创建一个Workbook对象,并选择要插入图片的工作表: ```python wb = Workbook() ws = wb.active ``` 3. 加载要插入图片,并将其转换为openpyxl的Image对象: ```python img = PILImage.open('image.jpg') img_xl = Image(img) ``` 4. 将Image对象插入到指定单元格中: ```python ws.add_image(img_xl, 'A1') ``` 5. 最后保存Excel文件: ```python wb.save('example.xlsx') ``` 完整代码示例: ```python from openpyxl import Workbook from openpyxl.drawing.image import Image from PIL import Image as PILImage wb = Workbook() ws = wb.active img = PILImage.open('image.jpg') img_xl = Image(img) ws.add_image(img_xl, 'A1') wb.save('example.xlsx') ``` ### 回答2: Python是一种高级编程语言,它可以用于不同的应用程序和任务,其中之一就是将图片插入Excel表中。在Python中,我们可以使用一些图像处理库和Excel操作库来实现这个功能。 首先,我们需要安装Python图像处理库。其中一个主流的库是Pillow库,它是Python Imaging Library的一个分支。Pillow库提供了各种图像处理和图形显示的函数和类。可以在Python中很方便地安装Pillow,只需要打开终端窗口或命令提示符窗口,然后键入以下命令: ```python pip install Pillow ``` 接下来,我们需要安装PythonExcel程序库,其中主要的库之一是openpyxl。它是用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。可以在Python中很方便地安装openpyxl,只需要打开终端窗口或命令提示符窗口,然后键入以下命令: ```python pip install openpyxl ``` 然后,我们可以使用Pillow库来读取并操作我们要插入Excel表格中的图像。将图像读取到Pillow对象中,可以使用Image.open()函数,例如: ```python from PIL import Image img = Image.open('your_image_path.jpg') ``` 然后,我们可以使用openpyxl库创建一个Excel文件,并将图像插入Excel表中。首先,我们需要使用Workbook()函数创建一个新的Excel文件对象,然后使用active属性选择第一个工作表。然后,我们可以使用add_image()函数将图像插入到单元格中,例如: ```python import openpyxl from openpyxl.drawing.image import Image wb = openpyxl.Workbook() sheet = wb.active img = Image('your_image_path.jpg') sheet.add_image(img, 'A1') wb.save('your_excel_file.xlsx') ``` 在上面的代码中,我们使用Image()函数将要插入Excel表中的图像读取到了openpyxl的Image对象中,然后使用add_image()方法将其插入到单元格“A1”中。最后,我们使用save()方法将Excel文件保存到本地磁盘上。 总的来说,通过使用Python的Pillow和openpyxl库,可以轻松地将图像插入Excel表格中。我们只需要读取图像,然后使用openpyxl库将其插入到合适的单元格中,最后将Excel文件保存到本地磁盘上即可。这个过程非常简单和直接,也很适合初学者使用。 ### 回答3: 在Python中,我们可以使用openpyxl和Pillow库来实现将图片插入Excel的操作。以下是详细步骤: 第一步:安装必要库 使用pip install指令安装openpyxl和Pillow库,可以使用以下命令: pip install openpyxl pip install Pillow 第二步:读取Excel文件 使用openpyxl的load_workbook函数来读取Excel文件,如下所示: from openpyxl import load_workbook workbook = load_workbook('example.xlsx') worksheet = workbook.active 第三步:插入图片 使用Pillow库的Image函数来读取图片,使用openpyxl的drawing函数来插入图片插入图片的具体步骤如下: from openpyxl.drawing.image import Image from openpyxl.utils import get_column_letter from openpyxl.drawing.image import Image img = Image('example.jpg') #设置单元格宽度和高度 worksheet.column_dimensions[get_column_letter(column)].width = img.width worksheet.row_dimensions[row].height = img.height #将图片插入单元格 worksheet.add_image(img, f"{get_column_letter(column)}{row}") 注意:需要根据图片所在的位置,设置单元格宽度、高度和行列编号。 第四步:保存Excel文件 使用openpyxl的save函数来保存Excel文件,如下所示: workbook.save('example.xlsx') 完整代码如下所示: from openpyxl import load_workbook from openpyxl.worksheet.dimensions import ColumnDimension, DimensionHolder from openpyxl.utils import get_column_letter from openpyxl.drawing.image import Image from openpyxl.utils import range_boundaries from openpyxl.worksheet.cell_range import CellRange from PIL import Image as IMG workbook = load_workbook('example.xlsx') worksheet = workbook.active img = Image('example.jpg') # 设置单元格宽度和高度 worksheet.column_dimensions[get_column_letter(2)].width = img.width worksheet.row_dimensions[2].height = img.height #将图片插入单元格 worksheet.add_image(img, f"B2") #保存Excel文件 workbook.save('example.xlsx')
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值