元素定位api
学习目标
- 掌握元素定位的基本方法
- 掌握定位一组元素
- 掌握设置等待时间
1.app元素定位操作API
1.1定位介绍
元素的基本定位基于当前屏幕范围内展示的可见元素
1.2 Appium常用定位方式
前置代码
from appium import webdriver # server 启动参数 desired_caps = {} # 设备信息 desired_caps['platforName'] = 'Android' desired_caps['paltformVersion'] = '5.1' desired_caps['deviceName'] = '192.168.56.101:5555' # app信息 desired_caps['appPackage'] = 'com.android.settings' desired_caps['appActivity'] = '.Settings' # 生命driver对象 driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub', desired_caps)
id
方法:find_element_by_id(id_value) # id_value:为元素的id属性值
需求:
通过id定位方式点击搜索按钮
举例:
driver.find_element_by_id("com.android.settings:id/search").click()
driver.quit()
- class
方法:find_element_by_class_name(class_value) # class_value:为元素的class属性值
需求:
1.进入设置页面
2.点击搜索按钮
3.通过class定位方式点击输入框的返回按钮
举例:
driver.find_element_by_id("com.android.settings:id/search").click()
driver.find_element_by_class_name("android.widget.ImageButton").click()
driver.quit()
- xpath
方法:find_element_by_xpath(xpath_value) # xpath_value:为可以定位到元素的xpath语句
Android端常用属性定位:
1. id ://*[contains(@resource-id,'com.android.settings:id/search')]
2. class ://*[contains(@class,'android.widget.ImageButton')]
3. text ://*[contains(@text,'WLA')]
模糊定位
4. contains(@key,value): value可以是部分值
需求:
1. 进入设置页面
2. 点击wlan菜单栏
示例:
driver.find_element_by_xpath("//*[contains(@text,'WLA')]").click()
driver.quit()
2. 定位一组元素
应用场景为元素值重复,无法通过元素属性直接定位到某个元素,只能通过elements方式来选择,返回一个定位对象的列表.
2.1 通过id定位一组元素
方法: find_elements_by_id(id_value)
需求:
1. 进入设置页面
2. 点击wlan菜单栏,id定位对象列表中第2个
title = driver.find_elements_by_id("com.android.settings:id/title")
# 打印title类型,预期为list
print(type(title))
# 取title返回列表中的第一个定位对象,执行点击操作
title[1].click()
2.2 通过class定位一组元素
方法: find_elements_by_class_name(class_value)
需求:
1. 进入设置页面
2. 点击wlan菜单栏,选择定位对象是第3个
title = driver.find_elements_by_class_name("android.widget.TextView")
# 打印title类型,预期为list
print(type(title))
# 取title返回列表中的第3个定位对象,执行点击操作
title[3].click()
2.3 通过Xpath定位一组元素
方法: find_elements_by_xpath(xpath_value)
需求:
1. 进入设置页面
2. 点击wlan菜单栏,xpath中class属性定位列表中第3个对象
data = driver.find_elements_by_xpath("//*[contains(@class,'android.widget.TextView')]")
data[3].click()
3.显示等待
3.1 显示等待介绍
在一个超时时间范围内,每隔一段时间去搜索一次元素是否存在,
如果存在返回定位对象,如果不存在直到超时时间到达,报超时异常错误。
3.2 显示等待方法
方法:WebDriverWait(driver, timeout, poll_frequency).until(method)
参数:
1.driver:手机驱动对象
2.timeout:搜索超时时间
3.poll_frequency:每次搜索间隔时间,默认时间为0.5s
4.method:定位方法(匿名函数)
使用示例:
WebDriverWait(driver, timeout, poll_frequency).until(lambda x: x.find_elements_by_id(id_value))
解释:
1.x传入值为:driver,所以才可以使用定位方法.
函数运行过程:
1.实例化WebDriverWait类,传入driver对象,之后driver对象被赋值给WebDriverWait的一个类变量:self._driver
2.until为WebDriverWait类的方法,until传入method方法(即匿名函数),之后method方法会被传入self._driver
3.搜索到元素后until返回定位对象,没有搜索到函数until返回超时异常错误.
示例:
try:
# 查找元素前时间
print(time.strftime("%H:%M:%S",time.localtime()))
# 显示等待
WebDriverWait(driver,15,1).until(lambdax:x.find_element_by_id("com.android.settings:id/search")).click()
except Exception as e:
# 查找元素后时间
print(time.strftime("%H:%M:%S",time.localtime()))