Appium安卓自动化元素定位怎么做

在Appium中,元素定位是自动化测试的关键步骤,主要通过find_element函数实现,如通过ID或XPATH等方式定位。UIAutomatorViewer工具用于查看和获取元素属性。推荐优先使用ID定位,若不唯一则使用XPATH。此外,文章提供了获取元素属性和执行操作的方法,并分享了相关资源,如软件测试面试题库。

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

无论想在 app 页面中进行怎样的操作,我们先得找到那个要操作的元素。比如你想直接点击一个按钮,那么你就必须要先找到这个按钮。如果你想在输入框当中去输入一些内容,那么你就必须要先找到这个输入框。

这个寻找需要操作的元素的过程,叫做元素定位。

元素定位函数

在大多数的APP操作过程当中,首先必须先找到需要操作的元素,这个过程就叫元素定位。

在Appium当中进行元素定位的函数叫 find_element,他传递两个参数。第1个参数是定位元素的方式, 第二个参数是这个方式的值。 举个例子,通过 ID 定位一个元素,第1个参数就填 id,第2个参数表示ID的值。

el = driver.find_element('id', 'value')
复制代码

得到的 el 是一个元素对象,获取元素的属性都很简单:

el.text  #获取元素文本
el.rect  #获取元素坐标
el.get_attribute('clickable')  #获取元素clickable属性
复制代码

元素定位工具:uiautomatorviewer

那么,id 的值到哪里去获取呢?在 SDK 中有一个 tools 目录,这个目录有一个叫 uiautomatorviewer 的工具,能查看每个元素的属性,当然也包括 id 属性。直接找到对应的文件,点击就能看到它的界面。

要查看一个元素的属性,只需把鼠标移动到元素上,右侧就会显示每个元素的属性。每一次点击 uiautomatorviewer 这个工具呢会比较麻烦对吧,去创建一个快捷访问方式,放到我们的桌面上,需要用到的时候,就直接在桌面上点击这个快捷方式就可以打开了。

元素定位方式

app 自动化测试主要的元素定位方式有几种:

  • MobileBy.XPATH
  • MobileBy.ID
  • MobileBy.ACCESSIBILITY_ID
  • MobileBy.ANDROID_UIAUTOMATOR
  • MobileBy.CLASS_NAME

id 和 xpath 是用得最多而且语法通用的两种方式,尽量使用 id 来定位,如果元素没有 id 属性或者 id 不唯一,再用 xpath 元素定位方式。

Xpath 是一种通用的路径定位语言,既可以用在 web 网页中,又可以用在 app 页面中,它可以通过组合多种属性条件让定位表达式更精确,具体的Xpath用法,可以参考XPath元素定位方式

其次 Android Uiautomator 这种方式适合在 Java 语言中使用,其他语言用起来不是很方便。如果需要,可以参考 官网 的用法。

通过查看页面属性,将复制出来的属性放到函数中,就可以定位元素了。比如查看到某个元素的 id 为 com.keda.say:id/username ,对应的代码就是:

driver.find_element('id', 'com.keda.say:id/username')
复制代码

也可以转写成 Xpath 表达式:

driver.find_element('xpath', '//*[@id="com.keda.say:id/username"]')
复制代码

获取元素属性

find_element 方法定位到元素后,会得到一个元素对象,使用这个对象能获取元素的属性,或者调用属性的方法和操作事件。

  • element.location_in_view
  • element.location
  • element.rect
  • element.text
  • element.get_attribute(‘clickable’)

总结

不管是什么情况下,做 ui 自动化只要使用了 find_element 方法,通过元素定位获取到了元素,后面才能对该元素执行操作。


绵薄之力

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

软件测试面试小程序

被百万人刷爆的软件测试题库!!!谁用谁知道!!!全网最全面试刷题小程序,手机就可以刷题,地铁上公交上,卷起来!

涵盖以下这些面试题板块:

1、软件测试基础理论 ,2、web,app,接口功能测试 ,3、网络 ,4、数据库 ,5、linux

6、web,app,接口自动化 ,7、性能测试 ,8、编程基础,9、hr面试题 ,10、开放性测试题,11、安全测试,12、计算机基础

获取方式 :

<think>我们正在讨论如何使用Appium进行微信小程序的自动化测试。根据引用内容,我们有两个相关引用:[^1]提到AirtestIDE可以用于微信小程序自动化测试,[^2]提到Xposed框架的安装配置。但用户明确询问的是Appium的实现方法。因此,我们需要将重点放在Appium上。关键点:使用Appium测试微信小程序需要特殊配置,因为微信小程序运行在WebView中,而微信的WebView是经过改造的,需要打开X5内核的调试开关。步骤:1.环境准备:安装Appium、配置Android SDK、Java环境等。2.设备准备:在测试设备(真机或模拟器)上安装微信,并开启X5内核调试模式。3.获取微信小程序的进程名和WebView上下文。4.编写测试脚本。详细步骤:###1.环境准备确保已安装:-AppiumServer-Appium Client(如Python的Appium-Python-Client)-Android SDK(配置adb等工具)- JavaJDK###2.设备准备在Android设备上开启开发者选项和USB调试模式。开启微信X5内核调试模式(两种方法):-方法一:在微信任意聊天窗口输入`http://debugx5.qq.com`并访问,进入调试页面,勾选“打开TBS内核Inspector调试功能”和“打开TBS内核X5debug调试功能”。-方法二(如果方法一无效):安装Xposed框架(如引用[^2]所述),然后安装Xposed插件(如XposedWeChatTools)来开启调试。注意:Xposed框架的安装需要设备已root(或模拟器),且安装过程较为复杂,引用[^2]中提到了Xposed的安装步骤。 ###3.获取小程序WebView上下文启动微信并进入小程序后,小程序运行在WebView中。我们需要获取其上下文(context)。在代码中,我们可以通过以下方式获取所有上下文:```pythoncontexts= driver.contextsprint(contexts)```通常,微信小程序的上下文名类似于`WEBVIEW_com.tencent.mm:toolsmp`或`WEBVIEW_X5`。###4.编写测试脚本示例脚本(Python):```pythonfromappium importwebdriverdesired_caps ={'platformName':'Android','deviceName':'your_device_name','appPackage':'com.tencent.mm','appActivity': '.ui.LauncherUI','noReset':True,#避免每次重置微信'chromedriverExecutable':'path/to/chromedriver'#需要与微信X5内核版本匹配的chromedriver}driver =webdriver.Remote('http://localhost:4723/wd/hub',desired_caps)#等待微信启动并进入小程序(这里需要根据实际情况操作进入小程序)#例如,点击微信底部的“发现”->“小程序”->选择目标小程序#获取所有上下文contexts =driver.contexts#切换到小程序的WebView上下文for contextin contexts:if 'WEBVIEW' incontext:driver.switch_to.context(context)break#现在可以在小程序页面中使用Selenium的API操作元素#例如,通过find_element_by_id等定位元素#测试完成后driver.quit()```注意:微信小程序的页面元素定位可以使用Chrome浏览器的远程调试功能。在Chrome地址栏输入`chrome://inspect`,然后确保设备已连接并授权,在微信小程序页面刷新,即可看到调试页面。关键问题:chromedriver的版本必须与微信X5内核的版本匹配。可以在微信的X5调试页面(`http://debugx5.qq.com`)查看X5内核版本,然后下载对应版本的chromedriver。###5.可能遇到的问题-无法切换上下文:确保已经开启了X5调试,并且小程序已经加载完成。-元素定位不到:可能需要等待页面加载完成,或者检查是否在正确的上下文。引用说明:[^1]中提到了AirtestIDE,但用户要求使用Appium,因此我们主要提供Appium的方法。不过,如果用户对Airtest感兴趣,可以建议作为替代方案。[^2]中提到的Xposed框架是开启调试的一种方法,尤其是在方法一失效的情况下。相关问题:1.如何定位微信小程序中的元素?2.如何解决chromedriver与微信X5内核版本不匹配的问题?3.除了Appium,还有哪些工具可以用于微信小程序自动化测试?</think>### Appium实现微信小程序自动化测试步骤 使用Appium进行微信小程序自动化测试的关键在于解决**小程序WebView调试**问题,以下是详细步骤: --- #### 1. **环境准备** - **设备要求**: - Android 5.0+ 设备(真机或模拟器) - 微信版本 ≥ 7.0(推荐最新版) - **工具安装**: ```bash # 安装Appium npm install -g appium # 安装Python客户端库 pip install Appium-Python-Client ``` - **驱动配置**: - 下载与设备**Chrome内核版本匹配**的[Chromedriver](https://chromedriver.chromium.org/) - 放置到Appium的`chromedriver`目录(路径通常在`/usr/local/lib/node_modules/appium/node_modules/appium-chromedriver/chromedriver/`) --- #### 2. **开启微信X5内核调试** 这是核心步骤,需在设备上操作: 1. 打开微信,进入任意聊天窗口 2. 输入调试地址:`http://debugx5.qq.com` 并访问 3. 在**调试页面**勾选: - ✅ 打开TBS内核Inspector调试功能 - ✅ 打开TBS内核X5debug调试功能 - ✅ 打开vConsole调试功能 ![X5调试页面示意图](https://debugx5.qq.com/assets/img/debug_enable.png) [^1] > **注意**:若真机无法开启,需使用**已ROOT的模拟器**(如MuMu/夜神)并通过Xposed框架强制开启[^2]。 --- #### 3. **Desired Capabilities配置** ```python from appium import webdriver caps = { "platformName": "Android", "deviceName": "emulator-5554", # adb devices获取 "appPackage": "com.tencent.mm", "appActivity": ".ui.LauncherUI", "noReset": True, # 保留微信登录状态 "chromedriverExecutable": "/path/to/matching_chromedriver", # 匹配的Chromedriver路径 "chromeOptions": { "androidProcess": "com.tencent.mm:appbrand0" # 小程序进程名 } } driver = webdriver.Remote('http://localhost:4723/wd/hub', caps) ``` --- #### 4. **切换小程序WebView上下文** 1. 手动操作进入目标小程序 2. 获取所有上下文: ```python contexts = driver.contexts # 返回示例:['NATIVE_APP', 'WEBVIEW_com.tencent.mm:toolsmp'] ``` 3. 切换到WebView: ```python driver.switch_to.context(contexts[-1]) # 通常最后一个为小程序上下文 ``` --- #### 5. **元素定位与操作** 使用Selenium标准API操作小程序页面: ```python # 定位搜索框并输入 search = driver.find_element(By.CSS_SELECTOR, '.search-input') search.send_keys("自动化测试") # 点击第一个结果 first_item = driver.find_element(By.XPATH, '//div[@class="result-item"][1]') first_item.click() ``` --- #### 6. **常见问题解决** - **无法切换WebView**: - 检查X5调试是否开启成功 - 确认Chromedriver版本匹配(微信X5内核版本可在`http://debugx5.qq.com`查看) - **元素无法定位**: - 使用Chrome远程调试:`chrome://inspect/#devices` - 通过`driver.page_source`获取页面结构 > **性能提示**:每次测试前**复用已登录的微信会话**(`noReset=True`),避免重复登录。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值