7

我正在尝试制作一个小功能,该功能将等到某个窗口出现然后发送按键(alt + i),我一直在尝试使用pywinauto执行此操作但没有成功。根据我在文档中读到的内容,我可以使用

pywinauto.application.WindowSpecification.Exists()

但我只是不明白如何指定我要查找的内容,我可以使用窗口标题或进程名称,但找不到很好的解释。

另外,除了 pywinauto 之外,还有没有更容易使用的模块?我不需要做复杂的自动化,只需等待一个窗口并发送一些密钥。

编辑

好的,我找到了一个解决方案,一个永远循环的简单函数

 def auto_accept(*args):
    while True:
        try:
            app = pywinauto.Application()
            app.window_(title='Untitled - Notepad').SetFocus()
            app.window_(title='Untitled - Notepad').TypeKeys("{1}{2}{3}")
        except (pywinauto.findwindows.WindowNotFoundError, pywinauto.timings.TimeoutError):
            pass

但现在我总是收到类似“2015-07-13 12:18:02,887 INFO: Typed text to the Notepad: {1}{2}{3}”的警告,我无法使用警告模块将它们过滤掉,还有另一种过滤\禁用它们的方法吗?这是一个问题,因为当我使用 py2exe 创建 exe 时,程序关闭后它告诉我有错误,但唯一的错误是我从 sendkeys 收到的警告。

4

1 回答 1

7

您可以简单地使用对象wait/wait_not的方法WindowSpecification

from pywinauto.application import Application
app = Application(backend="win32").start('executable')
app.WindowSpecification.wait('enabled').type_keys('%i') # % - alt, ^ - ctrl

WindowSpecification可以设置更多细节:

app.window(title='Title', class_name='#32770')

方法的所有可能参数与find_elements 函数window()相同(不建议直接使用此低级函数)。

对于长时间操作,您可以为单个等待wait('enabled', timeout=20)设置超时:或为每个wait全局设置超时:Timings.window_find_timeout = 10


import pywinauto编辑:在禁用日志记录后调用此代码:

import logging
logger = logging.getLogger('pywinauto')
logger.level = logging.WARNING # or higher

记录器级别:

Level Numeric value 
CRITICAL 50 
ERROR 40 
WARNING 30 
INFO 20 
DEBUG 10 
NOTSET 0 
于 2015-07-13T06:06:54.510 回答