python操作Excel时,只干掉当前Excel的进程?该怎么弄?有时用 DispatchEx打开时用workbook .Close(SaveChanges=0) # 关闭工作薄,不保存
excel.Quit() # 退出excel 发现进程没有关闭,如何只关闭当前excel进程?

python中操作Excel时,只干掉当前Excel的进程?
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
3条回答 默认 最新
- jingluan666 2020-08-16 14:22关注
我照着你说的那样open然后close再quit是可以退出的,实际只用close就可以退出
可能你的程序用有些特别的处理可以使用下面的方法,调用close_excel_by_force(excel)
def close_excel_by_force(excel): import time import win32process import win32gui import win32api import win32con hwnd = excel.Hwnd t, p = win32process.GetWindowThreadProcessId(hwnd) win32gui.PostMessage(hwnd, win32con.WM_CLOSE, 0, 0) time.sleep(10) try: handle = win32api.OpenProcess(win32con.PROCESS_TERMINATE, 0, p) if handle: win32api.TerminateProcess(handle, 0) win32api.CloseHandle(handle) except: pass
https://stackoverflow.com/questions/10221150/cant-close-excel-completely-using-win32com-on-python
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报