Appium元素定位
与Web自动化测试一样,app自动化测试过程中最重要一个环节就是元素定位,只有准确定位到了元素才能进行相关元素的操作,如输入、点击、拖拽、滑动等。appium提供了许多元素定位的方法,如id定位、name定位、class定位、层级定位等等.... 接下来将会给大家来实践运用这些定位技巧。
Appium元素定位方式
- id
- name
- class
- List定位
- 相对定位
- Xpath定位
- H5页面元素定位
- Uiautomator定位
id定位
日常生活中身边可能存在相同名字的人,但是每个人的身份证号码是唯一的,在app界面元素中也可以使用id值来区分不同的元素,然后进行定位操作。Appium中可以使用 find_element_by_id() 方法来进行id定位。
思考
- 如果安装的版本最新的包,或者升级到了最新的版本,则启动后没有升级弹窗元素该如何处理?
- 跳过引导页面首次启动和非首次启动场景该如何处理?
from appium import webdriver
from selenium.common.exceptions import NoSuchElementException #导入错误模块
desired_caps={'platformName':'Android',
'platforVersion':'4.2.2',
'deviceName':'127.0.0.1:62001',
'app':r'F:\APPium\kaoyan3.1.0.apk',
'appPackage':'com.tal.kaoyan',
'appActivity':'com.tal.kaoyan.ui.activity.SplashActivity',
'noReset':'True'}
driver=webdriver.Remote('http://localhost:4723/wd/hub',desired_caps)
driver.implicitly_wait(5)
try:
driver.find_element_by_id("android:id/button2").click()
except NoSuchElementException:
print(1)
try:
driver.find_element_by_id('com.tal.kaoyan:id/tv_skip').click()
except NoSuchElementException:
print(2)
** send_keys()传入中文时需要在capability中配置如下内容:
'unicodeKeyboard':'True' #中文编译
'resetKeyboard': 'True'
设置之后会有Appium的输入法守护来执行输入操作
注意:
使用Appium做了输入操作之后,如果出现输入法无法唤起,可以在系统设置——语言和输入法——将当前输入法替换为系统输入法或者其他输入法。
name定位
根据name进行定位,对于android来说,就是text属性
用法
driver.find_element_by_name('请输入用户名').send_keys('test')
driver.find_element_by_name('登录').click()
说明:由于text稳定性不是很好,所以appium 1.5开始废弃了该方法。
classname定位
classname定位是根据元素类型来进行定位,但是实际情况中很多元素的classname都是相同的,
driver.find_element_by_class_name('android.widget.EditText').send_keys('test')
driver.find_element_by_class_name('android.widget.EditText').send_keys('test')
driver.find_element_by_class_name('android.widget.Button').click()
如上例中登录页面中的用户名和密码都是clasName属性值都是:“android.widget.EditText” 因此只能定位到第一个元素也就是用户名,而密码输入框就需要使用其他方式来定位,这样其实很鸡肋.一般情况下如果有id就不必使用classname定位。
相对定位
相对定位是先找到该元素的有对应属性的父元素节点,然后基于父元素进行元素定位。
#先找到父节点交给一个变量
root_element=driver.find_element_by_id('com.tal.kaoyan:id/activity_register_parentlayout')
#用变量去查找元素
root_element.find_element_by_class_name('android.widget.ImageView').click()
xpath定位
xpath定位是一种路径定位方式,主要是依赖于元素绝对路径或者相关属性来定位,但是绝对路径xpath执行效率比较低(特别是元素路径比较深的时候),一般使用比较少。通常使用xpath相对路径和属性定位。
1.xpath路径表达式
表达式 | 描述 |
/ | 从根节点选取。 |
// | 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置。 |
nodename | 选取此节点的所有子节点。 |
. | 选取当前节点。 |
.. | 选取当前节点的父节点。 |
@ | 选取属性。 |
通配符 | 描述 |
* | 匹配任何元素节点。 |
@* | 匹配任何属性节点。 |
node() | 匹配任何类型的节点。 |
driver.find_element_by_xpath \ #找到所有tag
('//android.widget.EditText[@text="请输入用户名"]').send_keys('zxw1234')
driver.find_element_by_xpath \
('//*[@class="android.widget.EditText" and @index="3"]').send_keys('zxw123456')
driver.find_element_by_xpath('//android.widget.Button').click()
driver.find_element_by_xpath('//*[@class="android.widget.Button"]').click()
扩展资料:xpath语法
List定位
前面我们提到相同的classname属性值元素无法区分定位,那么在本节课将使用List定位来解决这个问题。List定位首先是使用find_elements_by_XX获取一组相同的class属性的元素,然后使用数组下标来区分标记不同元素进行相关操作。
images=driver.find_elements_by_id('com.tal.kaoyan:id/item_image')
images[10].click()
报错&解决方案
元素定位报错
selenium.common.exceptions.NoSuchElementException: Message: An element could not be located on the page using the given search parameters.
【解决方案】检查元素id值是否写错。
参考资料
https://blog.csdn.net/u011541946/article/details/77922304
UIAutomator定位简介
UIAutomator元素定位是 Android 系统原生支持的定位方式,虽然与 xpath 类似,但比它更加好用,且支持元素全部属性定位.定位原理是通过android 自带的android uiautomator的类库去查找元素。 Appium元素定位方法其实也是基于Uiautomator来进行封装的。
使用方法 find_element_by_android_uiautomator() 可以运用UiAutomator元素定位。
定位方法
- id定位
- text定位
- class name定位
id定位
id定位是根据元素的resource-id属性来进行定位,使用 UiSelector().resourceId()方法即可。
driver.find_element_by_android_uiautomator\
('new UiSelector().resourceId("com.tal.kaoyan:id/login_login_btn")').click()
text定位
text定位就是根据元素的text属性值来进行定位,new UiSelector()
driver.find_element_by_android_uiautomator\
('new UiSelector().text("请输入用户名")').send_keys('test')
class name定位
与Appium class定位方式一样,也是根据元素的class属性来进行定位。
driver.find_element_by_android_uiautomator\
('new UiSelector().className("android.widget.EditText")').send_keys('test')