activities
latest
false
UiPath logo, featuring letters U and I in white

UI Automation activities

Last updated Jan 14, 2026

About Selectors

To automate specific actions in the user interface, you are required to interact with various windows, buttons, drop-down lists and many others. One of the ways in which UI elements can be identified is by using their position on the screen, but this can be unreliable.

To overcome this problem, Studio uses what we call selectors. These store the attributes of a graphical user interface element and its parents, in the shape of an XML fragment.

Most of the times, selectors are automatically generated by Studio and do not require further input from you, especially if the apps you are trying to automate have a static user interface.

However, some software programs have changing layouts and attribute nodes with volatile values, such as some web-apps. Studio cannot predict these changes and, therefore, you might have to manually generate some selectors.

A selector has the following structure:

<node_1/><node_2/>...<node_N/>
<node_1/><node_2/>...<node_N/>

The last node represents the GUI element that interests you, and all the previous ones represent the parents of that element. <node_1> is usually referred to as a root node, and represents the top window of the app.

Each node has one or more attributes that help you correctly identify a specific level of the selected application.

Each node has the following format:

<ui_system attr_name_1='attr_value_1' ... attr_name_N='attr_value_N'/>
<ui_system attr_name_1='attr_value_1' ... attr_name_N='attr_value_N'/>

Every attribute has an assigned value. It is important to pick attributes with a constant value. If the value of an attribute changes each time the app is started, then the selector will not be able to correctly identify the element.

Selectors are displayed in the Properties panel of activities, under Input > Target > Selector. All activities related to graphical elements have this property.

docs image

The Selection Options window enables you to select and edit a target. To access this window, in the Workflow Designer panel, click the Options docs image button in the body of an activity and select Indicate target on screen or Edit target.

docs image

The Selector Editor window enables you to see the automatically-generated selector and edit it and its attributes. To access this window, use the Ellipsis button next to the Selector field, in the Properties panel.

docs image

Option

Description

Validate

The button shows the status of the selector by checking the validity of the selector definition and the visibility of the target element on the screen.

The Validate button has three states:

  • docs image Selector is being validated
  • docs image Valid selector
  • docs image Invalid selector
  • docs image Modified selector, revalidate

The button is correlated with UI Explorer validation states.

Indicate Element

Indicate a new UI element to replace the previous one.

Repair

Enables you to re-indicate the same target UI element and repair the selector. This operation does not completely replace the previous selector. The button is available only when the selector is invalid.

Highlight

Brings the target element in the foreground. The highlight stays on until the option is disabled with a click. The button is enabled only if the selector is valid.

Edit Attributes

Contains all the application components needed to identify the target application (a window, a button etc.). This section is editable.

Edit Selector

Holds the actual selector. This section is editable.

Open in UI Explorer

Launches the UI Explorer. The option is enabled only for valid selectors.

Note:

In some situations, when Studio and the targeted application are opened with different elevated privileges, the selector might not work. We recommend to always open both applications with the same privileges.

Supported Tags and Attributes

The following tables present the compatibility between tags and attributes used to build selectors and the selector capability.

On macOS the selector types wnd, ax, java, and sap can be used for different use cases:

  • AX selectors are available for all types of macOS desktop applications.

  • SAP selectors are available for SAP GUI for Java on macOS and require a SAP server with scripting enabled. These selectors are the most stable for SAP applications and offer the best range of features, like extracting table data.

  • Java selectors are available for Java applications. Since SAP GUI for Java is also a Java based application, one can use the Java selection strategy to switch from the default one and get Java selectors instead.

    Note:

    Selectors generated for Java applications which contain multiple WND tags cannot be used with events monitoring.

WND

AttributeFuzzyRegExCase-SensitiveOS
appWindows macOS
clsWindows
titleWindows macOS
aanameWindows
ctrlname (WinForms)Windows
ctrlid (WinForms)Windows
idxWindows macOS
tidWindows macOS
pidWindows macOS
isremoteappWindows
aastateWindows
rolemacOS
enabledmacOS
focusedmacOS
selectedmacOS
expandedmacOS
sapClient (SAP)Windows macOS
sapLanguage (SAP)Windows macOS
sapProgram (SAP)Windows macOS
sapScreen (SAP)Windows macOS
sapSession (SAP)Windows macOS
sapSysName (SAP)Windows macOS
sapSysNumber (SAP)Windows macOS
sapSysSessionId (SAP)Windows macOS
sapTransaction (SAP)Windows macOS
sapUser (SAP)Windows macOS
curlApplet (Curl)Windows

HTML

AttributeFuzzyRegExCase-SensitiveOS
urlWindows macOS Linux
htmlwindownameWindows macOS Linux
titleWindows macOS Linux
classWindows macOS Linux
appWindows macOS Linux
idxWindows macOS Linux
pidWindows macOS Linux
tidWindows macOS Linux
excludehwndWindows macOS Linux
bsid (Browser Session ID)Windows macOS Linux
isremoteappWindows macOS Linux

WEBCTRL

The tag and idx attributes use string values. All other WEBCTRL attributes have dynamic values.

AttributeFuzzyRegExCase-SensitiveOS
tagWindows macOS Linux
idxWindows macOS Linux
aanameWindows macOS Linux
nameWindows macOS Linux
idWindows macOS Linux
parentidWindows macOS Linux
classWindows macOS Linux
css-selectorWindows macOS Linux
innertextWindows macOS Linux
visibleinnertextWindows macOS Linux
isleafWindows macOS Linux
parentclassWindows macOS Linux
parentnameWindows macOS Linux
srcWindows macOS Linux
hrefWindows macOS Linux
tableColWindows macOS Linux
tableRowWindows macOS Linux
colNameWindows macOS Linux
rowNameWindows macOS Linux
aria-labelWindows macOS Linux
aria-labelledbyWindows macOS Linux

CTRL

AttributeFuzzyRegExCase-SensitiveOS
roleWindows
nameWindows
automationidWindows
labeledbyWindows
aastateWindows
virtualnameWindows
textWindows
rowNameWindows
idxWindows

UIA

AttributeFuzzyRegExCase-SensitiveOS
accelkey (Accelerator Key)Windows
acskey (Access Key)Windows
automationidWindows
clsWindows
helpTextWindows
legacyAccHelp (Legacy Accessible Help)Windows
enabledWindows
kbfocus (Is Keyboard Focusable)Windows
ispwd (Is Password)Windows
itemstatusWindows
itemtypeWindows
rtid (Runtime ID)Windows
roleWindows
nameWindows
pidWindows
tableRowWindows
tableColWindows
rowNameWindows
colNameWindows
idxWindows

JAVA

AttributeFuzzyRegExCase-SensitiveOS
roleWindows macOS
nameWindows macOS
virtualnameWindows macOS
javastateWindows macOS
tableRowWindows macOS
tableColWindows macOS
rowNameWindows macOS
colNameWindows macOS
idxWindows macOS
clsWindows macOS
accessibleClassWindows macOS

SAP

AttributeFuzzyRegExCase-SensitiveOS
idWindows macOS
leafid This attribute is not exposed in the Attribute panel because it is mutual-exclusive with the id attribute. It can be added manually.Windows macOS
tableRowWindows macOS
tableColWindows macOS
colNameWindows macOS
relpathWindows macOS
itemIdWindows macOS

AX

AttributeFuzzyRegExCase-SensitiveOS
rolemacOS
subrolemacOS
namemacOS
titlemacOS
identifiermacOS
filenamemacOS
urlmacOS
helpmacOS
enabledmacOS
focusedmacOS
selectedmacOS
expandedmacOS
idxmacOS
rowCountmacOS
columnCountmacOS
tableRowmacOS
tableColmacOS
rowNamemacOS
colNamemacOS

CURL

AttributeFuzzyRegExCase-SensitiveOS
clsWindows
roleWindows
textWindows
titleWindows
tableRowWindows
tableColWindows
colHeaderWindows
idxWindows

SILVERLIGHT

Please note that the Silverlight tag does not support Fuzzy, RegEx, and Case-Sensitive capabilities.

AttributeFuzzyRegExCase-SensitiveOS
roleWindows
nameWindows
textWindows
idxWindows

RDP

The RDP tag is used for remote automation and its attributes are identical to WND tag.

AttributeFuzzyRegExCase-SensitiveOS
appWindows
clsWindows
titleWindows
aanameWindows
ctrlname (WinForms)Windows
ctrlid (WinForms)Windows
idxWindows
tidWindows
pidWindows
  • Supported Tags and Attributes
  • WND
  • HTML
  • WEBCTRL
  • CTRL
  • UIA
  • JAVA
  • SAP
  • AX
  • CURL
  • SILVERLIGHT
  • RDP

Was this page helpful?

Get The Help You Need
Learning RPA - Automation Courses
UiPath Community Forum
Uipath Logo
Trust and Security
© 2005-2026 UiPath. All rights reserved.