Appium_5_元素定位

本文聚焦Appium元素定位,指出在app自动化测试中元素定位至关重要。介绍了多种定位方式,如id、name、classname、相对、xpath、List定位等,还提及UIAutomator定位,包括其定位原理和方法,同时给出元素定位报错的解决方案。

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

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.youkuaiyun.com/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')

 

### 解决Python `NameError` 错误 当遇到 `NameError: name 'post_title' is not defined` 这样的错误时,意味着程序尝试访问一个尚未定义或不在当前作用域内的变量。为了有效解决问题,可以从以下几个方面入手: #### 1. 变量声明位置检查 确保 `post_title` 的赋值发生在任何对该变量的引用之前。如果是在函数内部使用该变量,则需确认其初始化也在同一范围内完成。 #### 2. 拼写准确性验证 仔细核对代码中所有涉及 `post_title` 的地方是否有拼写的差异。即使是大小写字母的不同也会导致此问题的发生[^1]。 #### 3. 导入语句审查 如果是从其他模块导入的对象,务必保证相应的导入语句已经正确执行,并且路径无误。对于Selenium自动化测试而言,这可能涉及到浏览器驱动实例化等问题。 #### 4. 使用全局变量注意事项 如果打算在整个文件甚至多个文件间共享数据,请考虑通过适当的方式传递这些信息而不是依赖于全局命名空间来减少潜在冲突的风险。 针对具体场景下的Appium Demo项目,在编写用于导航至特定页面并操作UI组件(如点击按钮)以及设定断言逻辑的过程中,应该特别留意上述几点建议的应用情况。例如,在启动会话前配置好必要的环境参数;利用显式等待机制提高元素查找的成功率等措施有助于增强脚本稳定性。 ```python from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC driver = webdriver.Chrome() try: driver.get('http://example.com') # 显式等待直到找到指定ID的输入框可见后再继续下一步骤 search_box = WebDriverWait(driver, 10).until( EC.presence_of_element_located((By.ID, "searchBox")) ) post_title = "Test Title" search_box.send_keys(post_title) except Exception as e: raise ValueError(f"Failed to set up test environment or locate elements: {str(e)}") finally: driver.quit() ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值