Ste*_*nie 4 python vba excel-vba win32com python-2.7
我正在尝试使用python 2.7将一个excel工作表从工作簿A移动到工作簿B,但我一直收到错误.
Python脚本:
import win32com.client
excel=win32com.client.Dispatch('Excel.Application')
excel.Visible=False
wbP=excel.Workbooks.Open('C:\Full Path\WorkbookA.xlsx')
wbG=excel.Workbooks.Open('C:\Full Path\WorkbookB.xlsx')
wbG.Worksheets("Sheet1").Select
wbG.Worksheets("Sheet1").Move(before=wbP.Worksheets("Annual"))
wbP.SaveAs('C:\Full Path\WorkbookA.xlsx')
excel.Application.Quit()
Run Code Online (Sandbox Code Playgroud)
我收到的错误:
Traceback (most recent call last):
File "C:\Full Path\test.py", line 10, in <module>
wbG.Worksheets("Sheet1").Select
File "C:\Python27\lib\site-packages\win32com\gen_py\00020813-0000-0000-C000-000000000046x0x1x8\Sheets.py", line 120, in __call__
ret = self._oleobj_.InvokeTypes(0, LCID, 2, (9, 0), ((12, 1),),Index
com_error: (-2147352567, 'Exception occurred.', (0, None, None, None, 0, -2147352565), None)
Run Code Online (Sandbox Code Playgroud)
谢谢!
解:
请参阅bernie的评论.我需要移动的工作表名为Charts而不是Sheet1.
我正在回答这些评论,因为它更容易阅读......
由于该行发生错误,问题是WorkbookB.xlsx中没有"Sheet1"
以下是您可能希望在代码中更改的一些内容:
您可以使用win32com.client.DispatchEx创建新的Excel实例来避免干扰任何打开的Excel实例.如果你使用DispatchEx,你可以删除设置.Visible到False.关于DispatchEx这里的进一步阅读:http://timgolden.me.uk/python/win32_how_do_i/start-a-new-com-instance.html
\是一个逃脱角色.使用原始字符串或正斜杠,例如:wbG=excel.Workbooks.Open(r'C:\Full Path\WorkbookB.xlsx')或
wbG=excel.Workbooks.Open('C:/Full Path/WorkbookB.xlsx')
结合这些建议,代码变为:
from win32com.client import DispatchEx
excel = DispatchEx('Excel.Application')
wbP=excel.Workbooks.Open(r'C:\Full Path\WorkbookA.xlsx')
wbG=excel.Workbooks.Open(r'C:\Full Path\WorkbookB.xlsx')
# note altered sheet name; also .Select is not required
wbG.Worksheets("Charts").Move(Before=wbP.Worksheets("Annual"))
wbP.SaveAs(r'C:\Full Path\WorkbookA.xlsx')
excel.Quit()
del excel # ensure Excel process ends
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5235 次 |
| 最近记录: |