【Appium】如何定位元素?封装查找元素方法

本文介绍Appium中如何定位移动应用元素,包括查找单个元素和多个元素的方法,支持的定位策略如ID、XPath等,以及find_element和find_elements函数的来源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、查找1个元素

def findBy(self, by=By.ID, value=None):
    try:
        return self.driver.find_element_by_*(by, value)
    except:
        self.exception_handle2()
        return self.driver.find_element(by, value)

def find(self, locate) -> WebElement:
    return self.findBy(*locate)

具体使用:

_selected_icon2 = (MobileBy.ACCESSIBILITY_ID, 'option_selected_icon')
self.find(self._selected_icon2).click()

说明:如果_selected_icon2对应多个元素,这里只会取第一个

二、找到多个元素

def findAllBy(self, by=By.ID, value=None):
    try:
        return self.driver.find_elements_by_*(by, value)
    except:
        self.exception_handle2()
        return self.driver.find_elements(by, value)

def findAll(self, locate) -> []:
    return self.findAllBy(*locate)

具体使用:

_selected_icon2 = (MobileBy.ACCESSIBILITY_ID, 'option_selected_icon')
self.findAll(self._selected_icon2)[1].click()

三、目前支持哪些定位方式?

1、支持移动端常用定位方式
id
xpath
class name
accessibility id
2、不常用的也支持(但还没用过),以下为支持的定位方式
class By(object):
    """
    Set of supported locator strategies.
    """

    ID = "id"
    XPATH = "xpath"
    LINK_TEXT = "link text"
    PARTIAL_LINK_TEXT = "partial link text"
    NAME = "name"
    TAG_NAME = "tag name"
    CLASS_NAME = "class name"
    CSS_SELECTOR = "css selector"

class MobileBy(By):
    IOS_PREDICATE = '-ios predicate string'
    IOS_UIAUTOMATION = '-ios uiautomation'
    IOS_CLASS_CHAIN = '-ios class chain'
    ANDROID_UIAUTOMATOR = '-android uiautomator'
    ANDROID_VIEWTAG = '-android viewtag'
    ANDROID_DATA_MATCHER = '-android datamatcher'
    ACCESSIBILITY_ID = 'accessibility id'
    IMAGE = '-image'
    CUSTOM = '-custom'

四、find_element、find_elements从哪来的?

/appium/webdriver/webelement.py
-> find_element 部分
def find_element(self, by=By.ID, value=None):
    """Find an element given a By strategy and locator

    Prefer the find_element_by_* methods when possible.

    Args:
        by (:obj:`str`, optional): The strategy
        value (:obj:`str`, optional): The locator

    Usage:
        element = element.find_element(By.ID, 'foo')

    Returns:
        `appium.webdriver.webelement.WebElement`
    """
    # TODO: If we need, we should enable below converter for Web context
    # if self._w3c:
    #     if by == By.ID:
    #         by = By.CSS_SELECTOR
    #         value = '[id="%s"]' % value
    #     elif by == By.TAG_NAME:
    #         by = By.CSS_SELECTOR
    #     elif by == By.CLASS_NAME:
    #         by = By.CSS_SELECTOR
    #         value = ".%s" % value
    #     elif by == By.NAME:
    #         by = By.CSS_SELECTOR
    #         value = '[name="%s"]' % value

    return self._execute(RemoteCommand.FIND_CHILD_ELEMENT,
                         {"using": by, "value": value})['value']
-> find_elements 部分

def find_elements(self, by=By.ID, value=None):
    """Find elements given a By strategy and locator

    Prefer the find_elements_by_* methods when possible.

    Args:
        by (:obj:`str`, optional): The strategy
        value (:obj:`str`, optional): The locator

    Usage:
        element = element.find_elements(By.CLASS_NAME, 'foo')

    Returns:
        :obj:`list` of :obj:`appium.webdriver.webelement.WebElement`
    """
    # TODO: If we need, we should enable below converter for Web context
    # if self._w3c:
    #     if by == By.ID:
    #         by = By.CSS_SELECTOR
    #         value = '[id="%s"]' % value
    #     elif by == By.TAG_NAME:
    #         by = By.CSS_SELECTOR
    #     elif by == By.CLASS_NAME:
    #         by = By.CSS_SELECTOR
    #         value = ".%s" % value
    #     elif by == By.NAME:
    #         by = By.CSS_SELECTOR
    #         value = '[name="%s"]' % value

    return self._execute(RemoteCommand.FIND_CHILD_ELEMENTS,
                         {"using": by, "value": value})['value']

UIAutomator元素定位是Android系统原生支持的定位方式,通过使用android自带的android uiautomator的类库去查找元素。它比其他定位方式更加灵活且支持元素的全部属性定位。在Appium中,也是基于UIAutomator进行封装的。使用方法find_element_by_android_uiautomator()可以运用UIAutomator元素定位定位方法包括id定位、text定位和class name定位。此外,UIAutomator还支持递归地搜索元素,是一种强有力的定位方式。在Appium中,可以通过实例化一个UiSelector对象并通过实例接口调用来定位元素。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Appium学习18:Uiautomator元素定位](https://blog.youkuaiyun.com/up1292/article/details/104192339)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [Appium元素定位方式之android_uiautomator定位](https://blog.youkuaiyun.com/weixin_44740756/article/details/120175915)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值