MCPcopy Index your code
hub / github.com/pywinauto/pywinauto

github.com/pywinauto/pywinauto @0.6.9 sqlite

repository ↗ · DeepWiki ↗ · release 0.6.9 ↗
2,162 symbols 8,805 edges 99 files 1,793 documented · 83%
README

Donate Join the chat at https://gitter.im/pywinauto/pywinauto Documentation Status Windows Tests Linux Tests codecov.io Code Health Codacy Badge Code Quality: Python Total Alerts Conda Version

pywinauto

pywinauto is a set of python modules to automate the Microsoft Windows GUI. At its simplest it allows you to send mouse and keyboard actions to windows dialogs and controls, but it has support for more complex actions like getting text data.

Supported technologies under the hood: Win32 API (backend="win32"; used by default), MS UI Automation (backend="uia"). User input emulation modules mouse and keyboard work on both Windows and Linux.

Enjoying this?

Just star the repo or make a donation.

paypal

Your help is valuable since this is a hobby project for all of us: we do new features development during out-of-office hours. * In general the library tends to be cross-platform in the near future (Linux in 2018, macOS in 2019). * Reliable text based "record-replay" generator is also a high priority feature under development. * More feature requests and discusions are welcome in the issues.

Setup

pip

Execute pip install -U pywinauto

conda

Execute conda install -c conda-forge pywinauto

Documentation / Help

Simple Example

It is simple and the resulting scripts are very readable. How simple?

from pywinauto.application import Application
app = Application().start("notepad.exe")

app.UntitledNotepad.menu_select("Help->About Notepad")
app.AboutNotepad.OK.click()
app.UntitledNotepad.Edit.type_keys("pywinauto Works!", with_spaces = True)

MS UI Automation Example

More detailed example for explorer.exe:

from pywinauto import Desktop, Application

Application().start('explorer.exe "C:\\Program Files"')

# connect to another process spawned by explorer.exe
# Note: make sure the script is running as Administrator!
app = Application(backend="uia").connect(path="explorer.exe", title="Program Files")

app.ProgramFiles.set_focus()
common_files = app.ProgramFiles.ItemsView.get_item('Common Files')
common_files.right_click_input()
app.ContextMenu.Properties.invoke()

# this dialog is open in another process (Desktop object doesn't rely on any process id)
Properties = Desktop(backend='uia').Common_Files_Properties
Properties.print_control_identifiers()
Properties.Cancel.click()
Properties.wait_not('visible') # make sure the dialog is closed

Dependencies (if install manually)

  • Windows:
  • pyWin32
  • comtypes
  • six
  • Linux:
  • python-xlib
  • six
  • Optional packages:
  • Install Pillow (by pip install -U Pillow) to be able to call capture_as_image() method for making a control's snapshot.

Packages required for running unit tests

Run all the tests: python ./pywinauto/unittests/testall.py

Contribution

Pull requests are very welcome. Read Contribution Guide for more details about unit tests, coding conventions, etc.

Copyrights

Pywinauto for native Windows GUI was initially written by Mark Mc Mahon. Mark brought many great ideas into the life using power of Python. Further contributors are inspired of the nice API so that the development continues.

Starting from 0.6.0 pywinauto is distributed under the BSD 3-clause license. Pywinauto 0.5.4 and before was distributed under the LGPL v2.1 or later. * (c) The Open Source Community, 2015-2018 (0.6.0+ development) * (c) Intel Corporation, 2015 (0.5.x maintenance) * (c) Michael Herrmann, 2012-2013 (0.4.2) * (c) Mark Mc Mahon, 2006-2010 (0.4.0 and before)

Core symbols most depended-on inside this repo

deprecated
called by 291
pywinauto/__init__.py
get_item
called by 168
pywinauto/controls/uia_controls.py
send_message
called by 158
pywinauto/controls/hwndwrapper.py
click
called by 149
pywinauto/controls/hwndwrapper.py
start
called by 136
pywinauto/application.py
window_text
called by 131
pywinauto/base_wrapper.py
_to_keycode
called by 124
pywinauto/linux/keyboard.py
wrapper_object
called by 119
pywinauto/application.py

Shape

Method 1,663
Class 263
Function 234
Route 2

Languages

Python100%

Modules by API surface

pywinauto/controls/common_controls.py224 symbols
pywinauto/unittests/test_uiawrapper.py173 symbols
pywinauto/unittests/test_common_controls.py172 symbols
pywinauto/unittests/test_hwndwrapper.py117 symbols
pywinauto/controls/uia_controls.py116 symbols
pywinauto/unittests/test_application.py114 symbols
pywinauto/controls/hwndwrapper.py89 symbols
pywinauto/unittests/test_win32controls.py79 symbols
pywinauto/win32structures.py72 symbols
pywinauto/controls/uiawrapper.py64 symbols
pywinauto/controls/win32_controls.py61 symbols
pywinauto/base_wrapper.py60 symbols

Dependencies from manifests, versioned

Babel1.3 · 1×
Sphinx1.4.1 · 1×
mock2.0.0 · 1×
six1.10.0 · 1×

For agents

$ claude mcp add pywinauto \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact