天天看点

python 关闭窗口事件_Python – Windows关闭事件

使用win32api.setConsoleCtrlHandler()时,我能够从

Windows接收关闭/注销/ etc事件,并干净地关闭我的应用程序.

但是,这仅适用于在python.exe下运行应用程序(即,它具有控制台窗口),但不在pythonw.exe(无控制台窗口)下运行.

当您没有控制台且没有窗口可以接收这些事件时,Windows中是否有相同的方式来接收这些事件?或者,是否有一种隐藏控制台窗口的编程方式?

要明确 – 我的目标是能够成功接收Windows关闭/注销/等事件,而无需显示任何类型的控制台窗口.

编辑:

我一直在玩,而且我已经走得更远了.我为此写了一段测试代码.当我执行“taskkill / im pythonw.exe”时 – 它将收到该消息.

但是,当我在Windows上执行关机,重新启动或注销时,我没有收到任何消息.

这是整个事情:

""" Testing Windows shutdown events """

import win32con

import win32api

import win32gui

import sys

import time

def log_info(msg):

""" Prints """

print msg

f = open("c:\\test.log", "a")

f.write(msg + "\n")

f.close()

def wndproc(hwnd, msg, wparam, lparam):

log_info("wndproc: %s" % msg)

if __name__ == "__main__":

log_info("*** STARTING ***")

hinst = win32api.GetModuleHandle(None)

wndclass = win32gui.WNDCLASS()

wndclass.hInstance = hinst

wndclass.lpszClassName = "testWindowClass"

messageMap = { win32con.WM_QUERYENDSESSION : wndproc,

win32con.WM_ENDSESSION : wndproc,

win32con.WM_QUIT : wndproc,

win32con.WM_DESTROY : wndproc,

win32con.WM_CLOSE : wndproc }

wndclass.lpfnWndProc = messageMap

try:

myWindowClass = win32gui.RegisterClass(wndclass)

hwnd = win32gui.CreateWindowEx(win32con.WS_EX_LEFT,

myWindowClass,

"testMsgWindow",

0,

0,

0,

win32con.CW_USEDEFAULT,

win32con.CW_USEDEFAULT,

win32con.HWND_MESSAGE,

0,

hinst,

None)

except Exception, e:

log_info("Exception: %s" % str(e))

if hwnd is None:

log_info("hwnd is none!")

else:

log_info("hwnd: %s" % hwnd)

while True:

win32gui.PumpWaitingMessages()

time.sleep(1)

我觉得我离这儿很近,但我肯定错过了什么!