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>

questionAnswers(2)

yourAnswerToTheQuestion