动手之前要选对好工具。(既然是基于WIN32api 当然要用微软的专用的spyxx.exe,上手相当简单。比较专业 ,能查出当前桌面上所有的窗口句柄和类型。VC的那个绿色版的 spy++效果不强(Au3Info.exe也一样),无法追踪多级子窗口。 下面是简易代码:(实际上就是用钩子原理 网络上也可以找到)
-
import win32ui,win32con,pyHook,pythoncom,win32gui ,wx
-
def hookhandle(event):
-
-
if event.KeyID==9:#tab键值
-
try:
-
pwin=win32ui.FindWindow('AfxMDIFrame70',None)#主窗口 AfxMDIFrame70就是你用#spyxx.exe查找到的窗口类名
-
pwin1=win32ui.FindWindowEx(pwin,None,'MDIClient',None)
-
pwin2=win32ui.FindWindowEx(pwin1,None,'AfxFrameOrView70',None)
-
pwin3=win32ui.FindWindowEx(pwin2,None,"AfxOleControl70",None)
-
pwin4=win32ui.FindWindowEx(pwin3,None,None,"PatientCardControl Frame")
-
#可以根据窗口#的标题名称查找 标题名称一般外接程序是不变的 而类名有时是变化的 比如机器重启 关闭等
-
pwin5=win32ui.FindWindowEx(pwin4,None,"AfxMDIFrame70",None)
-
pwin6=win32ui.FindWindowEx(pwin5,None,"AfxWnd70",None)
-
pwin7=win32ui.FindWindowEx(pwin6,None,"#32770",None)
-
textbox=pwin7.GetDlgItem(222)#获取控件的ID
-
textbox2=pwin7.GetDlgItem(224)
-
buf='0x0'*1024
-
buf2='0x0'*1024
-
textbox.SendMessage(win32con.WM_SETTEXT,"")#先清空控件内容
-
textbox2.SendMessage(win32con.WM_SETTEXT,"")
-
oldlen=textbox.SendMessage(win32con.WM_GETTEXT,buf)
-
oldlen2=textbox2.SendMessage(win32con.WM_GETTEXT,buf2)
-
textbox.SendMessage(win32con.WM_SETTEXT,buf[0:oldlen]+str(blh))#发送消息 注意不能##用%s 替换 所以一般需要全局变量 来替换
-
textbox2.SendMessage(win32con.WM_SETTEXT,buf2[0:oldlen]+str(name))
-
except:
-
wx.LogMessage('没有发现可用的窗口!请确保程序已经运行')
-
-
-
hm = pyHook.HookManager()#初始实例
-
hm.KeyDown=hookhandle
-
hm.HookKeyboard()
-
pythoncom.PumpMessages(5000)#据说是winctype的新功能 延迟吧 具体什么也不清楚
-
hm.UnhookKeyboard()#释放键盘捕捉 好像效果不明显
-
#for i in range (0,40):
-
#win32api.Sleep(20)
-
#if win32ui.PumpWaitingMessages(0,-1):
-
win32api.PostQuitMessage(0)
-
# 退出监控消息 很关键 必须配合sys.setrecursionlimit(4000)使用效果##才明显 不然的话 程序无法退出。
-
#raise exceptions.SystemExit
-
-
-
def OnClose(self, event):
-
sys.setrecursionlimit(4000)#相当关键
-
self.Close(True)
-
self.Destroy()
阅读(8531) | 评论(0) | 转发(0) |