Não é possível fechar o Excel completamente usando o win32com no Python
Este é o meu código e encontrei muitas respostas paraVBA, .NET framework e é bastante estranho. Quando eu executo isso, o Excel fecha.
<code>from win32com.client import DispatchEx excel = DispatchEx('Excel.Application') wbs = excel.Workbooks wbs.Close() excel.Quit() wbs = None excel = None # <-- Excel Closes here </code>
Mas quando eu faço o seguinte, não fecha.
<code>excel = DispatchEx('Excel.Application') wbs = excel.Workbooks wb = wbs.Open('D:\\Xaguar\\A1.xlsm') wb.Close(False) wbs.Close() excel.Quit() wb = None wbs = None excel = None # <-- NOT Closing !!! </code>
Eu encontrei algumas respostas possíveis na pergunta Stack OverflowO processo do Excel permanece aberto após a interoperabilidade; método tradicional não funciona. O problema é que não é Python, e eu não achoMarshal.ReleaseComObject
eGC
. Eu examinei todas as demos em...site-packages/win32com
e outros.
Mesmo isso não me incomoda se eu puder pegar o PID e matá-lo.
Eu encontrei uma solução emKill processo baseado no nome da janela (win32).
Pode não ser o caminho adequado, mas um workround é:
<code>def close_excel_by_force(excel): import win32process import win32gui import win32api import win32con # Get the window's process id's hwnd = excel.Hwnd t, p = win32process.GetWindowThreadProcessId(hwnd) # Ask window nicely to close win32gui.PostMessage(hwnd, win32con.WM_CLOSE, 0, 0) # Allow some time for app to close time.sleep(10) # If the application didn't close, force close try: handle = win32api.OpenProcess(win32con.PROCESS_TERMINATE, 0, p) if handle: win32api.TerminateProcess(handle, 0) win32api.CloseHandle(handle) except: pass excel = DispatchEx('Excel.Application') wbs = excel.Workbooks wb = wbs.Open('D:\\Xaguar\\A1.xlsm') wb.Close(False) wbs.Close() excel.Quit() wb = None wbs = None close_excel_by_force(excel) # <--- YOU #@#$# DIEEEEE!! DIEEEE!!! </code>