我是一个新的win32com用户。下面是我将xlsx文件转换为网页并捕获单元格范围为.png的代码。我遇到的问题是有时候代码运行得很好,但有时会出现错误。
import os
import sys
import win32com.client
from win32com.client.gencache import EnsureDispatch
from win32com.client import constants
from win32com.client import DispatchEx
import PIL
from PIL import ImageGrab
# #---------------------------standalone--------------------------------
path = r'path'
Temp='folder'
#
## ---------------------------------------------------------------------
filename1='Images.html'
images='Images_files'
def A(source):
xl = EnsureDispatch('Excel.Application')
wb = xl.Workbooks.Open(yourExcelFile)
wb.SaveAs(newFileName, constants.xlHtml)
xl.Workbooks.Close()
xl.Quit()
del xl
Allsheets=[]
def B():
xlApp = win32com.client.DispatchEx('Excel.Application')
xlApp.Visible = True
wb = xlApp.Workbooks.Open(os.path.join(path,Temp,source))
for sh in wb.Sheets:
Allsheets.append(sh.Name)
num=1
array=["AC7:AF10", "AC28:AF31","AC49:AF52"]
for sheet_4 in Allsheets[:4]:
xlApp.Worksheets(sheet_4).Activate()
win32c = win32com.client.constants
ws = xlApp.ActiveSheet
for i in range(len(array)):
ws.Range(array[i]).CopyPicture(Format=win32c.xlBitmap)
img = ImageGrab.grabclipboard()
img.save(os.path.join(path,Temp,images,'TextBox0'+ f"{num:02}"+'.png'))
num=num+1
n=13
arry=["K5:M5","X5:Z5","K26:M26","X26:Z26","K47:M47","X47:Z47"]
for sheet_name in Allsheets[5:]:
xlApp.Worksheets(sheet_name).Activate()
win32c = win32com.client.constants
ws = xlApp.ActiveSheet
for i in range(len(arry)):
ws.Range(arry[i]).CopyPicture(Format=win32c.xlBitmap)
img = ImageGrab.grabclipboard()
img.save(os.path.join(path,Temp,images,'Avg0'+ f"{n:02}"+'.png'))
n=n+1
wb.Close(True)
xlApp.Quit()
for f in os.listdir(os.path.join(path,Temp)):
if f.endswith('.xlsx'):
source=f
yourExcelFile = os.path.join(path,Temp,source)
newFileName = os.path.join(path,Temp,filename1)
A(source)
B()
以上代码大多数情况下都可以正常工作,但是对于之前能够正常工作的相同输入数据,现在会抛出以下错误。我已经尝试删除gen_py并重新运行代码。我已经参考了几乎所有的解决方案,但目前没有任何清晰且有效的解决方法。请有人提供一个解决方案。
img.save(os.path.join(path,Temp,images,'TextBox0'+ f"{num:02}"+'.png'))
AttributeError: 'NoneType' object has no attribute 'save'
ImageGrab.grabclipboard()
返回了None
,即剪贴板中没有包含图像。 - Maximousecom_error: (-2147352567, '发生异常。', (0,'Microsoft Excel','Range 类的 CopyPicture 方法失败','xlmain11.chm',0,-2146827284),None)
。 - Python Bang