繁体   English   中英

python-尝试打开(大)Excel时win32com.client:pywintypes.com_error

[英]Python - win32com.client: pywintypes.com_error when trying to open a (large) Excel

我正在尝试使用win32com.client打开受密码保护的excelfile。
该文件有37列和28.140行。

我需要保持行数动态,因为将来的文件将具有不同的行数(或多或少)。 我在SO上找到了一个解决方案,该解决方案到目前为止对于较小的文件都可以正常工作。

这是我的代码:

import win32com.client as w3c
xlApp = w3c.Dispatch("Excel.Application")
password = 'Greatpassword'
path = 'filepath'
xlwb = xlApp.Workbooks.Open(path,False, True, None, Password=password)
xlws = xlwb.Sheets[0]


max_clm = 37

xlUp = -4162
max_row = xlws.Cells(xlws.Rows.Count, "A").End(xlUp).Row
print(max_clm, max_row)

data = list(xlws.Range(xlws.Cells(1, 1), xlws.Cells(max_row, max_clm)).Value)


df = pd.DataFrame(data)
df.columns = df.iloc[0]
df = df.drop(0)

xlwb.Close()
xlApp.Quit()

这是我收到的错误消息:

  File "C:\Program Files (x86)\Microsoft Visual Studio\Shared\Python36_64\lib\site-packages\win32com\client\dynamic.py", line 516, in __getattr__
ret = self._oleobj_.Invoke(retEntry.dispid,0,invoke_type,1)
pywintypes.com_error: (-2147352567, 'Exception occurred.', (0, None, None, None, 0, -2147352566), None)

使用“ win32api.FormatMessage(-2147352566)”,我得到的文本是:
"Out of present range."

此错误消息是什么意思,我该如何处理?

我重新检查了文件,以确保它具有行数(变量max_row)和列数(变量max_clm)。

print(max_clm, max_row)

给我37,28.140

提前致谢!
BR,
MG

显然,这是行不通的,因为excel文件中有很多“空白行”。

因此,我将真实的行复制并粘贴到新文件中,然后突然起作用。 我无法理解它,因为根据我的代码,max_row为28.140。

谁可以给我解释一下这个?
win32是否有最大行数?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM