27

是否可以使用 openpyxl 插入图像(jpeg、png 等)?

基本上我想在它下面放置一个带有图表的生成图像。

我在文档中没有看到任何内容,与代码的成熟度相比,这似乎有点缺乏。

4

5 回答 5

42

下面在单元格 A1 中插入图像。根据您的需要调整图像位置或自己处理 PIL 图像的创建并将其交给Image()

import openpyxl

wb = openpyxl.Workbook()
ws = wb.worksheets[0]
img = openpyxl.drawing.image.Image('test.jpg')
img.anchor = 'A1'
ws.add_image(img)
wb.save('out.xlsx')

在旧版本的 openpyxl 中,以下工作:

import openpyxl

wb = openpyxl.Workbook()
ws = wb.worksheets[0]
img = openpyxl.drawing.Image('test.jpg')
img.anchor(ws.cell('A1'))
ws.add_image(img)
wb.save('out.xlsx')
于 2013-03-18T18:07:08.073 回答
11

在当前版本的 openpyxl(至少到 2.4.5)中,您必须像这样调用 Image:

img = openpyxl.drawing.image.Image('test.jpg')

使用 Anthon 的示例:

import openpyxl

wb = openpyxl.Workbook()
ws = wb.worksheets[0]
img = openpyxl.drawing.image.Image('test.jpg')
img.anchor(ws.cell('A1'))
ws.add_image(img)
wb.save('out.xlsx')
于 2017-03-14T08:12:34.043 回答
8

提供有关如何执行此操作的完整更新。此解决方案使用 openpyxl 版本 2.4.5。

我将图像下载到本地目录,打开现有工作簿并与插入的图像一起保存。

import openpyxl
from openpyxl import load_workbook
from openpyxl import Workbook
from openpyxl.drawing.image import Image
from openpyxl.utils import coordinate_from_string

openpyxl_version = openpyxl.__version__
print(openpyxl_version)  #to see what version I'm running

# downloaded a .png to local directory manually from
# "https://www.python.org/static/opengraph-icon-200x200.png"

#change to the location and name of your image
png_loc = r'c:\users\me\opengraph-icon-200x200.png'

# test.xlsx already exists in my current directory 

wb = load_workbook('test.xlsx')
ws = wb.active
my_png = openpyxl.drawing.image.Image(png_loc)
ws.add_image(my_png, 'B3')
wb.save('test.xlsx')

结果:

在此处输入图像描述

于 2017-07-27T20:40:55.290 回答
1

这段代码对我有用:

import openpyxl

wb = openpyxl.Workbook()
ws = wb.worksheets[0]
ws.merge_cells('A1:A3')
img = openpyxl.drawing.image.Image('image.jpg')
row_number = 1
col_idx = 1
cell = ws.cell(row=row_number, column=col_idx)
ws.add_image(img)
wb.save('output.xlsx')
于 2018-11-16T05:34:26.393 回答
0

补充一下,我一直在使用 openpyxl==2.5.6 (使用 Python3.65),我不得不使用img.anchor('A1')而不是img.anchor(ws.cell('A1')).

import openpyxl

wb = openpyxl.Workbook()
ws = wb.worksheets[0]
img = openpyxl.drawing.Image('test.jpg')
img.anchor('A1')
ws.add_image(img)
wb.save('out.xlsx')
于 2019-02-05T10:38:12.307 回答