网站首页 > 知识剖析 正文
简介
和selenium类似,作为App自动化测试的主流框架,appium也是以webdriver为基础来自动化操作App的,所以对于元素定位,其实appium与selenium也是类似的,只是appium还有自己的安卓原生定位方式等方法,但是关于ID定位,name定位,xpath定位等,appium也是支持的,本篇文章就来给大家介绍一下xpath定位是如何在appium中大显神威的。
本文将以淘宝App为例,定位左上角的扫一扫按钮,介绍xpath定位方法在appium元素定位中的使用。
基础定位
- 如果元素text是唯一的,可以通过text文本定位 //*[@text=’text文本属性’]
代码如下:
python# 定位text
driver.find_element_by_xpath("//*[@text='扫一扫']").click()
- 如果元素id是唯一的,也可以id属性定位 //*[@resource-id=’id属性’]
python# 定位 resource-id
driver.find_element_by_xpath("//*[@resource-id='com.taobao.taobao:id/tv_scan_text']").click()
- class属性唯一的话,同样可以通过class属性定位,如//class和//*[@class=’class属性’]
python# 定位搜索框 //class属性
driver.find_element_by_xpath("//android.widget.EditText").click()
# 定位搜索框 //*[@class='class属性']
driver.find_element_by_xpath("//*[@class='android.widget.EditText']").click()
- content-desc属性定位 //*[@content-desc=’desc的文本’]
python#点登录/注册
driver.find_element_by_xpath("//*[@text='注册/登录']").click()
time.sleep(3)
#content-desc定位
driver.find_element_by_xpath("//*[@content-desc='帮助']").click()
contains模糊定位
contains是模糊匹配的定位方法,对于一个元素的id或者text不是固定的,但有一部分是固定的,这种就可以模糊匹配。比如元素的text,content-desc, class等
python# contains匹配text
driver.find_element_by_xpath('//*[contains(@text, "注册/登录")]').click()
time.sleep(3)
# contains匹配textcontent-desc
driver.find_element_by_xpath("//*[contains(@content-desc, '帮助')]").click()
#定位搜索框class
driver.find_element_by_xpath("//*[contains(@class, 'EditText')]").click()
time.sleep(3)
driver.back()
#定位id
driver.find_element_by_xpath("//*[contains(@resource-id, 'id/home_searchedit')]").click()
组合定位
如果一个元素有2个或更多属性,通过xpath也可以同时匹配2个属性,text, resource-id,class ,index,content-desc这些属性都能任意组合定位。
python# id和class属性 定位搜索框
id_class = '//android.widget.EditText[@resource-id="com.taobao.taobao:id/home_searchedit"]'
driver.find_element_by_xpath(id_class).click()
time.sleep(3)
driver.back()
# text和index属性 定位登录/注册
desc_class = '//*[@text="注册/登录" and @index="1"]'
driver.find_element_by_xpath(desc_class).click()
time.sleep(3)
# class和text属性 定位输入手机号
class_text = '//android.widget.EditText[@text="请输入手机号码"]'
driver.find_element_by_xpath(class_text).send_keys("512200893")
time.sleep(3)
# class和desc 定位帮助
id_desc = '//*[contains(@resource-id, "aliuser_menu_item_help") and @content-desc="帮助"]'
driver.find_element_by_xpath(id_desc).click()
层级定位
- 父元素定位子元素
如果一个元素,它除了class属性(class属性肯定会有),其它属性啥都没有,这种情况用上面方法就不适用了,这个时候可以找他父元素,通过父亲定位儿子。
python#通过父亲定位儿子 搜索输入框
fa_sun = '//*[@resoure-id="com.taobao.taobao:id/home_searchbar"]/android.widget.EditText'
t = driver.find_element_by_xpath(father_son).text
print(t)
如果一个父元素下,有多个相同class的儿子时候,可以通过xpath的索引去取对应第几个,xpath是从0开始数的。
python# 父元素下第2个儿子 微淘
fu_sun2 = '//*[@resource-id="com.taobao.taobao:id/ll_navigation_tab_layout"]/android.widget.FrameLayout[2]'
driver.find_element_by_xpath(father_son).click()
- 子元素定位父元素
python# 通过子元素定位父元素
# 方法一: ..
sun_fa1 = '//*[@resource-id="com.taobao.taobao:id/tv_scan_text"]/..'
c = driver.find_element_by_xpath(son_father).tag_name
print(c)
# 方法二 parent::*
sun_fa2 = '//*[@resource-id="com.taobao.taobao:id/tv_scan_text"]/parent::*'
d = driver.find_element_by_xpath(son_father).tag_name
print(d)
# 方法三 parent::android.widget.LinearLayout
sun_fa3 = '//*[@resource-id="com.taobao.taobao:id/tv_scan_text"]/parent::android.widget.LinearLayout'
e = driver.find_element_by_xpath(son_father).tag_name
print(e)
- 定位兄弟元素
通过子元素,先找到父元素,再找父元素下的子元素,就可以找到兄弟元素
python# 兄弟元素
xiongdi = '//*[@resource-id="com.taobao.taobao:id/bar_search"]/../android.widget.RelativeLayout'
x = driver.find_element_by_xpath(brother).tag_name
print(x)
- 定位祖元素
python#爷爷元素FrameLayout---第一个FrameLayout儿子---孙子TextView
x = '//android.widget.FrameLayout/android.widget.LinearLayout[1]/android.widget.TextView'
t = driver.find_elements_by_xpath(x)
print(len(t))
# 打印文本信息
print(t[0].text
总结
XPath 是在 Appium 中进行元素定位的一种常用策略,它提供了灵活且强大的定位能力,有助于测试人员编写稳健的自动化测试脚本。通过本文提供的指南,我们可以更加熟练地使用 XPath 在 Appium 中进行元素定位,并加速移动应用的测试开发。
- 上一篇: 如何用xpath根据下面方框里的文字定位到上面标签?
- 下一篇: python中xpath学习笔记
猜你喜欢
- 2025-08-03 206.C# XML读取XPath
- 2025-08-03 python中xpath学习笔记
- 2025-08-03 如何用xpath根据下面方框里的文字定位到上面标签?
- 2025-08-03 「2022 年」崔庆才 Python3 爬虫教程 - 网页解析利器 XPath 初体验
- 2025-08-03 WebDriver-工具辅助生成XPath语法和CSS语法
- 2025-08-03 XPath语法实战简介
- 2025-08-03 Python+Requests+Xpath+lxml 数据采集
- 2025-08-03 python爬虫之xpath解析
- 2025-08-03 Python爬虫之xpath用法全解析
- 2025-08-03 Python解析库lxml与xpath用法总结
- 08-03mysql 工作时工作日函数 计算两个时间间隔分钟数
- 08-03开源鸿蒙OpenHarmony 5.1.0(API 18)正式上线:进一步增强ArkUI
- 08-03MySql
- 08-03MYSQL自动导出某表数据到EXCEL的方案
- 08-03MySQL进行整库数据备份「表(结构+数据)、视图、函数、事件」
- 08-03SQL高效使用20招:数据分析师必备技巧
- 08-03MySQL 中时间函数详解,及加减计算总结和使用!
- 08-03MySQL 日期函数
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)