Skip to main content

GUI automation tool

Project description

Guibot GH Actions Documentation Status CodeQL codecov

A tool for GUI automation using a variety of computer vision and display control backends.

Introduction and concepts

In order to do GUI automation you usually need to solve two problems: first, you need to have a way to control and interact with the interface and platform you are automating and second, you need to be able to locate the objects you are interested in on the screen. Guibot helps you do both.

To interact with GUIs, Guibot provides the controller module which contains a common interface for different display backends, with methods to move the mouse, take screenshots, type characters and so on. The backend to use will depend on how your platform is accessible, with some backends running directly as native binaries or python scripts on Windows, macOS, and Linux while others connecting through remote VNC displays.

To locate an element on the screen, you will need an image representing the screen, a target representing the element (an image or a text in the simplest cases) and a finder configured for the target. The finder looks for the target within the screenshot image and returns the coordinates to the region where that target appears. Finders, just like display controllers, are wrappers around different backends supported by Guibot that could vary from a simplest 1:1 pixel matching by controller backends, to template or feature matching mix by OpenCV, to OCR and ML solutions by Tesseract and AI frameworks.

Finally, to bridge the gap between controlling the GUI and finding target elements, the region module is provided. It represents a subregion of a screen and contains methods to locate targets in this region using a choice of finder and interact with the graphical interface using a choice of controller.

Supported backends

Supported Computer Vision (CV) backends are based on

  • OpenCV
    • Template matching
    • Contour matching
    • Feature matching
    • Haar cascade matching
    • Template-feature and mixed matching
  • Tesseract OCR
    • Text matching through pytesseract, tesserocr, or OpenCV's bindings
  • PyTorch
    • R-CNN matching through Faster R-CNN or Mask R-CNN
  • autopy
    • AutoPy matching

Supported Display Controller (DC) backends are based on

Further resources

Homepage: http://guibot.org

Documentation: http://guibot.readthedocs.io

Installation: https://github.com/intra2net/guibot/wiki/Packaging

Issue tracking: https://github.com/intra2net/guibot/issues

Project wiki: https://github.com/intra2net/guibot/wiki

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

guibot-0.51.1.tar.gz (3.1 kB view details)

Uploaded Source

Built Distribution

guibot-0.51.1-py3-none-any.whl (86.8 kB view details)

Uploaded Python 3

File details

Details for the file guibot-0.51.1.tar.gz.

File metadata

  • Download URL: guibot-0.51.1.tar.gz
  • Upload date:
  • Size: 3.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.8

File hashes

Hashes for guibot-0.51.1.tar.gz
Algorithm Hash digest
SHA256 f9e83f54c09fa69d94f585e45bd61116f90f7f99f729ebacff5061050a6c06da
MD5 332d8ced9a9704f2714eb4340b9bcd45
BLAKE2b-256 6daa5d717f4493d556ca530b56b25cd42aa60a913c361f1dc9464b17501826a5

See more details on using hashes here.

File details

Details for the file guibot-0.51.1-py3-none-any.whl.

File metadata

  • Download URL: guibot-0.51.1-py3-none-any.whl
  • Upload date:
  • Size: 86.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.8

File hashes

Hashes for guibot-0.51.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c26e9524912190f155be5f3a80314b8af549e43230ea0ba6e5cf32af2af9bae3
MD5 ba0f60e2e4df5df56f6449e551cb230a
BLAKE2b-256 e736c1c15a493b17a9990ecc8d66235cc2113517f38cc5e371d7a89a364d48d4

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page