gpt4 book ai didi

python-3.x - 使用 openpyxl 将图像插入 Excel

转载 作者:行者123 更新时间:2023-12-03 23:15:24 25 4
gpt4 key购买 nike

我的电脑崩溃了,所以我不得不重新安装我所有的库;完成安装后,我意识到一些库更新到了新版本,我的代码不再有效(由于 openpyxl 的新版本)。

我正在尝试将图像插入 Excel 文件,但我不明白发生的错误消息。其他问题似乎是针对旧版本的 openpyxl(我的原始代码对其有效),但不适用于当前版本的 openpyxl。感谢您帮助我了解如何修复我的代码。 :)

原始代码(有效):

import openpyxl
wb = openpyxl.load_workbook(filename)
ws = wb.get_sheet_by_name(sheet_name)
img = openpyxl.drawing.image.Image(img_name)
img.anchor(ws['D2'])
ws.add_image(img)
wb.save(filename)

当前代码(不起作用):
import openpyxl
wb = openpyxl.load_workbook(filename)
ws = wb[sheet_name]
img = openpyxl.drawing.image.Image(img_name)
img.anchor(ws.cell(row=2,column=4))
ws.add_image(img)
wb.save(filename)

错误信息:
---------------------------------------------------------------------------
TypeError Traceback (most recent call last)
<ipython-input-5-9efc1289cc73> in <module>()
----> 1 img.anchor(ws.cell(row=2,column=4))

TypeError: 'str' object is not callable

任何提示?

谢谢

编辑:显然, img.anchor 现在是字符串;我不知道它曾经是什么,但显然不是字符串(因为没有错误消息。现在更改为以下内容会设置 anchor ,但我收到一条不同的错误消息。

设置 anchor :
img.anchor = ws.cell(row=2,column=4)
ws.add_image(img)

但是现在尝试保存时崩溃:
---------------------------------------------------------------------------
AttributeError Traceback (most recent call last)
<ipython-input-13-2cfd938ccf60> in <module>()
1 img.anchor = ws.cell(row=2,column=4)
2 ws.add_image(img)
----> 3 wb.save(filename)

AttributeError: 'Cell' object has no attribute 'upper'

最佳答案

好玩的东西。显然,在我拥有的任何版本的 openpyxl 和我现在拥有的版本(2.5.5)之间,img.anchor 改变了类型。它现在是一个字符串而不是工作表位置,因此您只需将其设置为位置(在我的情况下:'D2')而不是工作表位置(不要使用 ws['D2'])。总结一下,当尝试用openpyxl 2.5.5插入图片时,使用如下:

import openpyxl
wb = openpyxl.load_workbook(filename)
ws = wb[sheet_name]
img = openpyxl.drawing.image.Image(img_name)
img.anchor = 'D2' # Or whatever cell location you want to use.
ws.add_image(img)
wb.save(filename)

关于python-3.x - 使用 openpyxl 将图像插入 Excel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51953494/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com