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

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

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

▲.需要注意在windows和mac下接口参数可能有所不同。

win32虽然也可控制键盘,但不如使用PyUserInput的方便。安装PyUserInput教程

from pymouse import PyMouse
from pykeyboard import PyKeyboard
#实例化
m = PyMouse()
k = PyKeyboard()x_dim, y_dim = m.screen_size()
# 鼠标点击 参数:x,y,button=1(左键)、2(右键)、3(中间),次数
m.click(x_dim, y_dim, button=1,n=1)
# 键盘输入 参数:str,间隔
k.type_string('Hello, World!',interval=0)# 按住一个键
k.press_key('H')
# 松开一个键
k.release_key('H')# 相当于===>按住并松开,tap一个键
k.tap_key('e')
# tap支持重复的间歇点击键,参数:str,次数,间隔
k.tap_key('l',n=2,interval=5) #创建组合键===>press_key和release_key结合使用
k.press_key(k.alt_key)
k.tap_key(k.tab_key)
k.release_key(k.alt_key)# 特殊功能键
k.tap_key(k.function_keys[5]) # Tap F5
k.tap_key(k.numpad_keys['Home']) # Tap 'Home' on the numpad
k.tap_key(k.numpad_keys[5], n=3) # Tap 5 on the numpad, thrice# Mac系统按键
k.press_keys(['Command','shift','3'])
# Windows系统按键
k.press_keys([k.windows_l_key,'d'])其中pymouse的PyMouseEvent和pykeyboard的PyKeyboardEvent还可用于监听鼠标和键盘事件的输入
class Clickonacci(PyMouseEvent):def __init__(self):PyMouseEvent.__init__(self)self.fibo = fibo()def click(self, x, y, button, press):'''Print Fibonacci numbers when the left click is pressed.'''if button == 1:if press:print('Press times:%d'.format(press))else: # Exit if any other mouse button usedself.stop()C = Clickonacci()
C.run()class TapRecord(PyKeyboardEvent):def __init__(self):PyKeyboardEvent.__init__(self)def tap(self, keycode, character, press):print(time.time(), keycode, character, press)t = TapRecord()
t.run()
#这些对象是一个架构用于监听鼠标和键盘的输入;他们除了监听之外不会做任何事,需要继承重构他们#PyKeyboardEvent为编写完成,所以这里是一个继承PyMouseEvent的例子:

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

python win32api win32gui win32con PyUserInput实现自动化脚本相关推荐

  1. python + win32api,win32gui,win32con 写 exe 窗口的时候,怎么创建按钮呢?

    问题描述: 自己用 python + win32api 想写 exe 脚本文件,但是按钮都不会创建 python + win32api,win32gui,win32con 写 exe 窗口的时候,怎么 ...

  2. python控制windows窗口、并输入数据_python win32api win32gui win32con 窗口句柄 发送消息 常用方法 键盘输入...

    import win32gui import win32con import win32api # 从顶层窗口向下搜索主窗口,无法搜索子窗口 # FindWindow(lpClassName=None ...

  3. python给窗口发送消息_python win32api win32gui win32con 窗口句柄 发送消息 常用方法 键盘输入...

    import win32gui import win32con import win32api # 从顶层窗口向下搜索主窗口,无法搜索子窗口 # FindWindow(lpClassName=None ...

  4. 【python】学会这八个自动化脚本,摸鱼的借口那不就来啦~

    前言 嗨喽~大家好呀,这里是魔王呐 ! 锄禾曰当午,上班好辛苦. 上完一上午,还要上下午. 不上没钱花,心里更痛苦. 为了好日子,辛苦就辛苦 --来自不知何方神圣改编的诗 在我们工作的时候~经常会做一 ...

  5. APPium+Python编写真机移动端自动化脚本

    前置条件 完成软件和环境的安装后就可以开始移动端自动化脚本的编写了. 连接设备 手机打开USB调试模式,连接手机.此时去命令窗口查看自己的设备是否已经连接. 让后打开Appium Server,进行配 ...

  6. appnium+python+夜神模拟器编写第一个自动化脚本

    1>前言 之前已经搭好了appnium和安卓环境,本章介绍下基于模拟器实现自动化测试,会引入3个知识:1.安卓模拟器的对接这套自动化环境的相关配置:2.利用安卓工具uiautomatorview ...

  7. Python接口自动化脚本业务框架总概(一)

    目录 接口自动化框架目录 基础类封装概览 基础类封装方法详解 Log.py文件 Request.py文件 Python是目前主流的接口自动化脚本语言之一. 本专栏将联系业务介绍使用python接口自动 ...

  8. Python 中的 4 个非常好用的自动化脚本

    这里有一些很棒的自动化脚本,你可以在你的 Python 项目中使用它们.在做项目的时候,我们需要一些现成的代码来帮助我们解决日常生活中的问题.本文为你的 Python 项目提供了4个自动化脚本,可以解 ...

  9. 如何将功能测试用例转为自动化脚本?

    如何设计自动化测试用例或脚本? 自动化始终遵循手动测试.通常,将在AUT上执行一轮或多轮手动测试.这意味着手动测试用例已经存在并且已经执行了至少一次. 例如,假设以下是您的手动测试用例.它只是登录到G ...

  10. Python 在windows上跑图色脚本?简单又好玩,自己编写一个自动化脚本

    Python 在windows上跑图色脚本?简单又好玩,自己编写一个自动化脚本 大家好 我又来开新坑了,如图这次准备用python弄个简单脚本(根据图色判断进行键鼠操作) 1.老规矩 先安排运行环境 ...

最新文章

  1. Gartner发布2021年重要战略科技趋势
  2. python自动客服排班_使用或工具的护士排班问题,在某些日子增加不同的轮班时间...
  3. 五分钟教你如何用函数计算部署钉钉群发机器人
  4. OpenJudge NOI 1.16 08:石头剪刀布
  5. 宇宙总统(洛谷-P1781)
  6. Gson实现自定义解析json格式
  7. 大众正式发布ID. Buzz 造型致敬经典
  8. mysql workbench 数据备份_如何使用MySQL Workbench进行MySQL数据库备份?
  9. iOS各个版本的新特性介绍
  10. 在希望的田野上--生物柴油(Biodiesel)光明的未来
  11. 微信公众号调用扫一扫,使扫一扫支持扫PDF417格式的条码
  12. [C++] Kmeans算法实现
  13. java-微信语言amr文件转码为Mp3文件
  14. 宇视科技实习生笔试面试经历
  15. Java分离中文姓名姓氏和名字
  16. 【报名】RT-Thread师资培训,苏州大学王怀宜教授主讲!
  17. 如何将JSONArray转为String数组
  18. Microbit Turnipbit 孩子也能做的声光控开关
  19. css实现滚动条兼容mac和windows
  20. 项目Demo —— socket下载器

热门文章

  1. 两数相除 leetcode
  2. presto执行一条查询分为七步
  3. 多态与虚函数(C++)
  4. 数据分块算法java_分块查询算法(JAVA)
  5. CS231n李飞飞计算机视觉 迁移学习之物体定位与检测上
  6. 【POJ 2482】【扫描线问题】Stars in Your Window【包星星问题】
  7. php构造函数里抛出异常_构造函数、析构函数抛出异常的问题
  8. 简单的页面表格导出Excel
  9. 微言Netty:分布式服务框架
  10. Java_学生信息管理系统——数组版——初次编写