当前位置:   article > 正文

python win32api win32gui win32con PyUserInput实现自动化脚本

pyuserinput脚本会

pywin32用spy++工具查找到句柄,再结合PyUserInput就能很好地实现自动化脚本。

  1. import win32gui
  2. import win32con
  3. import win32api
  4. # 从顶层窗口向下搜索主窗口,无法搜索子窗口
  5. # FindWindow(lpClassName=None, lpWindowName=None) 窗口类名 窗口标题名
  6. handle = win32gui.FindWindow("Notepad", None)
  7. # 获取窗口位置
  8. left, top, right, bottom = win32gui.GetWindowRect(handle)
  9. #获取某个句柄的类名和标题
  10. title = win32gui.GetWindowText(handle)
  11. clsname = win32gui.GetClassName(handle)
  12. # 打印句柄
  13. # 十进制
  14. print(handle)
  15. # 十六进制
  16. print("%x" %(handle) )
  17. # 搜索子窗口
  18. # 枚举子窗口
  19. hwndChildList = []
  20. win32gui.EnumChildWindows(handle, lambda hwnd, param: param.append(hwnd), hwndChildList)
  21. # FindWindowEx(hwndParent=0, hwndChildAfter=0, lpszClass=None, lpszWindow=None)
  22. # 父窗口句柄 若不为0,则按照z-index的顺序从hwndChildAfter向后开始搜索子窗体,否则从第一个子窗体开始搜索。 子窗口类名 子窗口标题
  23. subHandle = win32gui.FindWindowEx(handle, 0, "EDIT", None)
  24. # 获得窗口的菜单句柄
  25. menuHandle = win32gui.GetMenu(subHandle)
  26. # 获得子菜单或下拉菜单句柄
  27. # 参数:菜单句柄 子菜单索引号
  28. subMenuHandle = win32gui.GetSubMenu(menuHandle, 0)
  29. # 获得菜单项中的的标志符,注意,分隔符是被编入索引的
  30. # 参数:子菜单句柄 项目索引号
  31. menuItemHandle = win32gui.GetMenuItemID(subMenuHandle, 0)
  32. # 发送消息,加入消息队列,无返回
  33. # 参数:句柄 消息类型 WParam IParam
  34. win32gui.postMessage(subHandle, win32con.WM_COMMAND, menuItemHandle, 0)
  35. # wParam的定义是32位整型,high word就是他的3116位,low word是它的150位。
  36. # 当参数超过两个,wParam和lParam不够用时,可以将wParam就给拆成两个int16来使用。
  37. # 这种时候在python里记得用把HIWORD的常数向左移16位,再加LOWORD,即wParam = HIWORD<<16+LOWORD。
  38. # 下选框内容更改
  39. # 参数:下选框句柄; 消息内容;
  40. #参数下选框的哪一个item,以0起始的待选选项的索引;如果该值为-1,将从组合框列表中删除当前选项,并使当前选项为空;
  41. # 参数CB_Handle为下选框句柄,PCB_handle下选框父窗口句柄
  42. if win32api.SendMessage(CB_handle, win32con.CB_SETCURSEL, 1, 0) == 1:
  43. # 下选框的父窗口命令
  44. # 参数:父窗口句柄; 命令;
  45. # 参数:WParam:高位表示类型,低位表示内容;参数IParam,下选框句柄
  46. # CBN_SELENDOK当用户选择了有效的列表项时发送,提示父窗体处理用户的选择。 LOWORD为组合框的ID. HIWORD为CBN_SELENDOK的值。
  47. win32api.SendMessage(PCB_handle, win32con.WM_COMMAND, 0x90000, CB_handle)
  48. # CBN_SELCHANGE当用户更改了列表项的选择时发送,不论用户是通过鼠标选择或是通过方向键选择都会发送此通知。LOWORD为组合框的ID. HIWORD为CBN_SELCHANGE的值。
  49. win32api.SendMessage(PCB_handle, win32con.WM_COMMAND, 0x10000, CB_handle)
  50. # 设置文本框内容,等窗口处理完毕后返回true。中文需编码成gbk
  51. # 参数:句柄;消息类型;
  52. # 参数WParam,无需使用;
  53. # 参数IParam,要设置的内容,字符串
  54. win32api.SendMessage(handle, win32con.WM_SETTEXT, 0, os.path.abspath(fgFilePath).encode('gbk'))
  55. # 控件点击确定,处理消息后返回0
  56. # 参数:窗口句柄; 消息类型; 参数WParam HIWORD为0(未使用),LOWORD为控件的ID; 参数IParam 0(未使用),确定控件的句柄
  57. win32api.SendMessage(Mhandle, win32con.WM_COMMAND, 1, confirmBTN_handle)
  58. # 获取窗口文本不含截尾空字符的长度
  59. # 参数:窗口句柄; 消息类型; 参数WParam; 参数IParam
  60. bufSize = win32api.SendMessage(subHandle, win32con.WM_GETTEXTLENGTH, 0, 0) +1
  61. # 利用api生成Buffer
  62. strBuf = win32gui.PyMakeBuffer(bufSize)
  63. print(strBuf)
  64. # 发送消息获取文本内容
  65. # 参数:窗口句柄; 消息类型;文本大小; 存储位置
  66. length = win32gui.SendMessage(subHandle, win32con.WM_GETTEXT, bufSize, strBuf)
  67. # 反向内容,转为字符串
  68. # text = str(strBuf[:-1])
  69. address, length = win32gui.PyGetBufferAddressAndLen(strBuf)
  70. text = win32gui.PyGetString(address, length)
  71. # print('text: ', text)
  72. # 鼠标单击事件
  73. #鼠标定位到(30,50)
  74. win32api.SetCursorPos([30,150])
  75. #执行左单键击,若需要双击则延时几毫秒再点击一次即可
  76. win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP | win32con.MOUSEEVENTF_LEFTDOWN, 0, 0, 0, 0)
  77. #右键单击
  78. win32api.mouse_event(win32con.MOUSEEVENTF_RIGHTUP | win32con.MOUSEEVENTF_RIGHTDOWN, 0, 0, 0, 0)
  79. def click1(x,y): #第一种
  80. win32api.SetCursorPos((x,y))
  81. win32api.mouse_event(win32con.MOUSEEVENTF_LEFTDOWN,x,y,0,0)
  82. win32api.mouse_event(win32con.MOUSEEVENTF_LEFTUP,x,y,0,0)
  83. def click2(x,y): #第二种
  84. ctypes.windll.user32.SetCursorPos(x,y)
  85. ctypes.windll.user32.mouse_event(2,0,0,0,0)
  86. ctypes.windll.user32.mouse_event(4,0,0,0,0)
  87. def click_it(pos): #第三种
  88. handle= win32gui.WindowFromPoint(pos)
  89. client_pos =win32gui.ScreenToClient(handle,pos)
  90. tmp=win32api.MAKELONG(client_pos[0],client_pos[1])
  91. win32gui.SendMessage(handle, win32con.WM_ACTIVATE,win32con.WA_ACTIVE,0)
  92. win32gui.SendMessage(handle, win32con.WM_LBUTTONDOWN,win32con.MK_LBUTTON,tmp)
  93. win32gui.SendMessage(handle, win32con.WM_LBUTTONUP,win32con.MK_LBUTTON,tmp)
  94. # 发送回车
  95. win32api.keybd_event(13,0,0,0)
  96. win32api.keybd_event(13,0,win32con.KEYEVENTF_KEYUP,0)
  97. # 关闭窗口
  98. win32gui.PostMessage(win32lib.findWindow(classname, titlename), win32con.WM_CLOSE, 0, 0)
  99. # 检查窗口是否最小化,如果是最大化
  100. if(win32gui.IsIconic(hwnd)):
  101. # win32gui.ShowWindow(hwnd, win32con.SW_SHOWNORMAL)
  102. win32gui.ShowWindow(hwnd, 8)
  103. sleep(0.5)
  104. # SW_HIDE:隐藏窗口并激活其他窗口。nCmdShow=0
  105. # SW_MAXIMIZE:最大化指定的窗口。nCmdShow=3
  106. # SW_MINIMIZE:最小化指定的窗口并且激活在Z序中的下一个顶层窗口。nCmdShow=6
  107. # SW_RESTORE:激活并显示窗口。如果窗口最小化或最大化,则系统将窗口恢复到原来的尺寸和位置。在恢复最小化窗口时,应用程序应该指定这个标志。nCmdShow=9
  108. # SW_SHOW:在窗口原来的位置以原来的尺寸激活和显示窗口。nCmdShow=5
  109. # SW_SHOWDEFAULT:依据在STARTUPINFO结构中指定的SW_FLAG标志设定显示状态,STARTUPINFO 结构是由启动应用程序的程序传递给CreateProcess函数的。nCmdShow=10
  110. # SW_SHOWMAXIMIZED:激活窗口并将其最大化。nCmdShow=3
  111. # SW_SHOWMINIMIZED:激活窗口并将其最小化。nCmdShow=2
  112. # SW_SHOWMINNOACTIVE:窗口最小化,激活窗口仍然维持激活状态。nCmdShow=7
  113. # SW_SHOWNA:以窗口原来的状态显示窗口。激活窗口仍然维持激活状态。nCmdShow=8
  114. # SW_SHOWNOACTIVATE:以窗口最近一次的大小和状态显示窗口。激活窗口仍然维持激活状态。nCmdShow=4
  115. # SW_SHOWNORMAL:激活并显示一个窗口。如果窗口被最小化或最大化,系统将其恢复到原来的尺寸和大小。应用程序在第一次显示窗口的时候应该指定此标志。nCmdShow=1

感谢python win32api win32gui win32con 窗口句柄 发送消息 常用方法 键盘输入,代码主要来自于他

▲.需要注意在windows和mac下接口参数可能有所不同。
win32虽然也可控制键盘,但不如使用PyUserInput的方便。安装PyUserInput教程
  1. from pymouse import PyMouse
  2. from pykeyboard import PyKeyboard
  3. #实例化
  4. m = PyMouse()
  5. k = PyKeyboard()
  6. x_dim, y_dim = m.screen_size()
  7. # 鼠标点击 参数:x,y,button=1(左键)、2(右键)、3(中间),次数
  8. m.click(x_dim, y_dim, button=1,n=1)
  9. # 键盘输入 参数:str,间隔
  10. k.type_string('Hello, World!',interval=0)
  11. # 按住一个键
  12. k.press_key('H')
  13. # 松开一个键
  14. k.release_key('H')
  15. # 相当于===>按住并松开,tap一个键
  16. k.tap_key('e')
  17. # tap支持重复的间歇点击键,参数:str,次数,间隔
  18. k.tap_key('l',n=2,interval=5)
  19. #创建组合键===>press_keyrelease_key结合使用
  20. k.press_key(k.alt_key)
  21. k.tap_key(k.tab_key)
  22. k.release_key(k.alt_key)
  23. # 特殊功能键
  24. k.tap_key(k.function_keys[5]) # Tap F5
  25. k.tap_key(k.numpad_keys['Home']) # Tap 'Home' on the numpad
  26. k.tap_key(k.numpad_keys[5], n=3) # Tap 5 on the numpad, thrice
  27. # Mac系统按键
  28. k.press_keys(['Command','shift','3'])
  29. # Windows系统按键
  30. k.press_keys([k.windows_l_key,'d'])
  31. 其中pymouse的PyMouseEvent和pykeyboard的PyKeyboardEvent还可用于监听鼠标和键盘事件的输入
  32. class Clickonacci(PyMouseEvent):
  33. def __init__(self):
  34. PyMouseEvent.__init__(self)
  35. self.fibo = fibo()
  36. def click(self, x, y, button, press):
  37. '''Print Fibonacci numbers when the left click is pressed.'''
  38. if button == 1:
  39. if press:
  40. print('Press times:%d'.format(press))
  41. else: # Exit if any other mouse button used
  42. self.stop()
  43. C = Clickonacci()
  44. C.run()
  45. class TapRecord(PyKeyboardEvent):
  46. def __init__(self):
  47. PyKeyboardEvent.__init__(self)
  48. def tap(self, keycode, character, press):
  49. print(time.time(), keycode, character, press)
  50. t = TapRecord()
  51. t.run()
  52. #这些对象是一个架构用于监听鼠标和键盘的输入;他们除了监听之外不会做任何事,需要继承重构他们#PyKeyboardEvent为编写完成,所以这里是一个继承PyMouseEvent的例子:

转载于:https://www.cnblogs.com/nymrli/p/9559495.html

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号