Where communities thrive

  • Join over 1.5M+ people
  • Join over 100K+ communities
  • Free without limits
  • Create your own community
Repo info
  • Jan 25 01:09
    jiliguluss opened #1171
  • Jan 22 14:25
    vasily-v-ryabov labeled #1166
  • Jan 22 14:25
    vasily-v-ryabov labeled #1166
  • Jan 22 14:24
    vasily-v-ryabov commented #1166
  • Jan 22 13:13
    codecov[bot] commented #1162
  • Jan 22 11:15
    EOKruglov synchronize #1162
  • Jan 18 19:30
    basicAuto commented #563
  • Jan 18 19:30
    basicAuto commented #563
  • Jan 17 13:07
    mkq10 commented #563
  • Jan 14 18:23
    EOKruglov synchronize #1162
  • Jan 14 18:19
    vectar7 opened #1170
  • Jan 13 11:57
    claell opened #1169
  • Jan 13 11:50
    claell commented #1167
  • Jan 12 20:13
    EOKruglov synchronize #1162
  • Jan 12 14:44
    claell commented #1168
  • Jan 12 14:42
    claell opened #1168
  • Jan 12 14:36
    claell opened #1167
  • Jan 12 11:33
    bananoviiblinchik commented #1166
  • Jan 12 05:06
    Avnsx edited #1166
  • Jan 12 05:06
    Avnsx opened #1166
hello sir

app = Application(backend='uia')

rect = app.window(title='Blizzard Battle.net Login').rectangle()

i receive a error message like this:::

C:\Users\Administrator\AppData\Local\Programs\Python\Python37\python.exe "C:/Program Files (x86)/Battle.net/Bot/AutoController.py"
Traceback (most recent call last):
File "C:\Users\Administrator\AppData\Local\Programs\Python\Python37\lib\site-packages\pywinauto\application.py", line 256, in __resolve_control
File "C:\Users\Administrator\AppData\Local\Programs\Python\Python37\lib\site-packages\pywinauto\timings.py", line 458, in wait_until_passes
raise err

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
File "C:/Program Files (x86)/Battle.net/Bot/AutoController.py", line 20, in <module>
a = app.window(title='Blizzard Battle.net Login').rectangle()
File "C:\Users\Administrator\AppData\Local\Programs\Python\Python37\lib\site-packages\pywinauto\application.py", line 378, in getattribute
ctrls = self.resolve_control(self.criteria)
File "C:\Users\Administrator\AppData\Local\Programs\Python\Python37\lib\site-packages\pywinauto\application.py", line 259, in
raise e.original_exception
File "C:\Users\Administrator\AppData\Local\Programs\Python\Python37\lib\site-packages\pywinauto\timings.py", line 436, in wait_until_passes
func_val = func(args, *kwargs)
File "C:\Users\Administrator\AppData\Local\Programs\Python\Python37\lib\site-packages\pywinauto\application.py", line 201, in __get_ctrl
dialog = self.backend.generic_wrapper_class(findwindows.find_element(
File "C:\Users\Administrator\AppData\Local\Programs\Python\Python37\lib\site-packages\pywinauto\findwindows.py", line 87, in find_element
raise ElementNotFoundError(kwargs)
pywinauto.findwindows.ElementNotFoundError: {'title': 'Blizzard Battle.net Login', 'backend': 'uia', 'process': 29520}

Process finished with exit code 1

Vasily Ryabov
@SnakeGeneral let’s start from app.windows() then. Try method .window_text() for every wrapper object returned in a list of app.windows().
thank you sir
Vasily Ryabov
Login window might be a child of another top level window. It’s typical situation for “uia” backend.
much thanks.

Hello, I have error, can U help me?

def tab1_check(self):
app3 = Application()
global tab1_connect
tab1_connect = app3.process

def tab1_sod(self):
app2 = Application(backend="uia").connect(process=f'{tab1_connect}', visible_only=False)

    s_o_d = app2.window(process=f'{tab1_connect}')

raise ProcessNotFoundError('Process with PID={} not found!'.format(self.process))

pywinauto.application.ProcessNotFoundError: Process with PID=16508 not found!

Vasily Ryabov
process param is an integer PID (process id). Why using f-string? :) Also it’s possible that you face the launcher process that spawns a child one. Use connect by title with optional timeout to connect to proper process. We have feature request to implement auto detection of child processes, but it’s not expected soon.
Mohamed Hamdy
hello all can anyone advice the best setup approach for the pywinauto over win10 64 bit ?
tried python 3.8.1, 3.6 and no luck i always get AttributeError: module 'pywinauto' has no attribute 'application'
using pycharm and the python console works ok when i state from pywinauto import Application
Vasily Ryabov
Hi @draconlord do you mean Python 3.7.6? Both these Python versions have wrong fix for “passing union by value”. The wrong fix is already reverted in Python. Wait for Python 3.8.2 or use 3.8.0 or 3.7.5.
Mohamed Hamdy
@vasily-v-ryabov thank buddy i got it working now
i have a question the app im trying to automate uses check box list not detected by any GUI inspection tool, i know this is app related but i thought you guys could help its a C++ app and i even cant get this dialog using resource hacker either its identified as "pane" class = GLISTCLASS
Vasily Ryabov
@draconlord is it GTK+ app? Everything is bad with GTK on Windows. Really the worst case.
Linux is much much better working with GTK from accessibility point of view.
Vasily Ryabov
@aswathy53408765_twitter let's continue in this room in English.
Mohamed Hamdy
@vasily-v-ryabov it's windows based and all I can get from sniffers scans that it's a VC++ mfc app and not readable by any automation app i.e: ranorex just an element and a scroll bar
Vasily Ryabov
@draconlord I’m in doubt if this is really MFC app. All MFC apps are perfect for automation. Maybe only top level window is an MFC container that contains GTK+ components as children. Can you provide a few screenshots from Inspect.exe in UI Automation mode? For the list and for the main window?
I’ve googled what is GLISTCLASS and it’s GTK. Maybe main window is an MFC container that owns child GTK controls. A few screenshots from Inspect.exe would be helpful.
Mohamed Hamdy
@vasily-v-ryabov here's what inspect shows:
How found: Mouse move (1033,446)
hwnd=0x000709D6 32bit class="GLISTCLASS" style=0x50A00000 ex=0x200
RuntimeId: "[42.461270]"
BoundingRectangle: {l:866 t:369 r:1130 b:549}
ProcessId: 13220
ControlType: UIA_PaneControlTypeId (0xC371)
LocalizedControlType: "pane"
Name: ""
AccessKey: ""
HasKeyboardFocus: false
IsKeyboardFocusable: true
IsEnabled: true
AutomationId: "1"
HelpText: ""
IsPassword: false
NativeWindowHandle: 0x709D6
IsOffscreen: false
FrameworkId: "Win32"
ProviderDescription: "[pid:7084,providerId:0x709D6 Main:Nested [pid:13220,providerId:0x709D6 Annotation(parent link):Microsoft: Annotation Proxy (unmanaged:uiautomationcore.dll); Main:Microsoft: MSAA Proxy (unmanaged:uiautomationcore.dll)]; Nonclient:Microsoft: Non-Client Proxy (unmanaged:uiautomationcore.dll); Hwnd(parent link):Microsoft: HWND Proxy (unmanaged:uiautomationcore.dll)]"
Scroll.HorizontalScrollPercent: 0.000000
Scroll.HorizontalViewSize: 100.000000
Scroll.VerticalScrollPercent: 0.000000
Scroll.VerticalViewSize: 1.898734
Scroll.HorizontallyScrollable: false
Scroll.VerticallyScrollable: true
IsDockPatternAvailable: false
IsExpandCollapsePatternAvailable: false
IsGridItemPatternAvailable: false
IsGridPatternAvailable: false
IsInvokePatternAvailable: false
IsMultipleViewPatternAvailable: false
IsRangeValuePatternAvailable: false
IsScrollPatternAvailable: true
IsScrollItemPatternAvailable: false
IsSelectionItemPatternAvailable: false
IsSelectionPatternAvailable: false
IsTablePatternAvailable: false
IsTableItemPatternAvailable: false
IsTextPatternAvailable: false
IsTogglePatternAvailable: false
IsTransformPatternAvailable: false
IsValuePatternAvailable: false
IsWindowPatternAvailable: false
IsItemContainerPatternAvailable: false
IsVirtualizedItemPatternAvailable: false
FirstChild: "Vertical" scroll bar
LastChild: "Vertical" scroll bar
Next: (null) title bar
Previous: "" dialogue
Other Props: Object has no additional properties
Children: "Vertical" scroll bar
Ancestors: "Derivatives" window
"View Selection for [Desktop\test.lay]" dialogue
"LayMan - [Desktop\test.lay] " window
"Desktop 1" pane
[ No Parent ]
Vasily Ryabov
@draconlord looks like you're out of luck. Sorry.
Is it possible to obtain a control from cursor?
Vasily Ryabov
@LexiconCode from pywinauto import Desktop; Desktop(backend="uia").from_point(x, y)
That was very helpful thank you!

A couple questions regarding the following code.

from pywinauto import Application
app = Application(backend="uia").connect(process=15900) # Notepad
dlg = app['Untitled - Notepad']
# Timed start
text = app['dlg']['Edit'].get_value() #  329ms to grab the text control
# Timed stop
  1. Is there a faster way to retrieve "get_value" before caching?
  2. Reviewing the documentation for https://pywinauto.readthedocs.io/en/latest/code/pywinauto.controls.uia_controls.html#pywinauto.controls.uia_controls.EditWrapper I am a bit confused. I would like to retrieve additional information such as get_value's line_count(). I think I'm confusing the difference between the edit control and its element?

In general my end goal is to be able to:

- Grab Edit/document controls text body
- caret index from beginning of document to current caret position 
- anchor index beginning line index
- anchor position
- grab line index anchor position from the line index. caret indexed at the beginning of the line
- setting the caret/anchor position 

However it seems that caret/anchor is not implemented in pywinauto

Vasily Ryabov
Hi @LexiconCode the faster way to find EditWrapper is using more precise window specification like cached_edit = app.window(title="Main window title").child_window(control_type="Edit", found_index=0).wrapper_object(); chached_edit.get_value() because pre-filtering by control_type reduces list of interesting elements dramatically and it's very fast. So we don't have to retrieve title/text of all elements which is expensive.
1 reply
Vasily Ryabov
Setting caret position can be done by cached_edit.select(caret_index, caret_index) to select empty range of the text. Method .selection_indices() should return currect selection. It might be unreliable to get caret position because caret can be at start of at end of selection. So this is interesting question. Maybe we need to submit enhancement request to GitHub issues.
7 replies
You can try to experiment with cached_edit.iface_text.DocumentRangeobject. For example list all its attributes by dir(doc_range).

So this is interesting question. Maybe we need to submit enhancement request to GitHub issues.

Here is how to grab caret position for the current element using UIautomation in C++ or C#. Would that be enough information start up issue as an enhancement?

2 replies

Hello, I have developed a Pywinauto "Record/Replay" tool. There is still a lot of work to do but I would like to have first opinions and I'm looking for beta testers.

Here is a small video presentation:
Youtube presentation

I just realized that pywinauto_recorder.exe doesn't work on all machines (I'll fix this problem later). So to test it I advise you to download the ZIP archive of the clone: https://github.com/beuaaa/pywinauto_recorder/archive/master.zip
Hey guys I just started getting familiar with PyWinAuto and I created a basic calculator (WPF console in Visual studio 2019) and got the executable for it. I know how to open the application which goes something like app = Application(backend="uia").start('calculator.exe') but I'm not familiar with calling the buttons on my calculator. I have inspect.exe to help me out with the UI element properties so I can see the ControlType but I am not sure how to apply it here
I was thinking something like app.type_key('1*3=')
Vasily Ryabov
Hi @Bromus93_twitter it's worth reading the whole Getting Started Guide. It explains window specification concept and how to find particular element (and its wrapper).
@vasily-v-ryabov that was very helpful thank you
So I was able to click on the delete button on my calculator but for some reason whenever I try clicking on any of the special characters like 7, 8 or +, it tells me that Im using invalid syntax. I ran the print_control>identifiers() to make sure that I can see the child windows which I was able to. I did something like app.Off.click() and that worked fine but if i do something like app.7.click() then it doesnt work. Is it because it doesnt like the format of the button's title
Vasily Ryabov
Yes, because attribute name has the same limitations as variable name. It can’t start from digit or special character because of Python syntax. Use app[“7”].click() instead. Item access has no such restrictions. Any string is OK.
Hey guys is there a version of selected_item_index() from the ListBox for TreeView? I couldnt find it anywhere and was wondering if there was a way to retrieve the index of a tree item
And this is for Win32
Swaraj Kumar Barik
Hi All
I'm new to Pywinauto
While I started my application, the pop up opens & closes automatically
how can we handle this?
Vasily Ryabov
Hi @swaraj_barik_twitter please read the Getting Started Guide first, then Waiting for Long Operations. Methods wait() and wait_not() is what you need with proper window specifications.