appium+python自动化28-name定位

前言

appium1.5以下老的版本是可以通过name定位的,新版本从1.5以后都不支持name定位了

name定位报错

1.最新版appium V1.7用name定位,报错:

selenium.common.exceptions.InvalidSelectorException: Message: Locator Strategy 'name' is not supported for this session

2.这个报错是说name这个定位方法目前已经不支持了,因为appium从1.5版本开始就已经抛弃了name这种定位方法了。

xpath定位

1.既然name定位抛弃了,那就说明有更先进的定位代替了它,事实上xpath定位里面已经包含了name这种定位方法。

2.平常用过selenium,在定位页面上文本的时候,应该知道这个xpath语法:

//*[text()='页面text文本']

appium里面的xpath语法跟selenium有一点点区别:

//*[@text='页面text文本']

text属性

1.上面的xpath语法适合页面上这个text属性是唯一的,才好直接定位到,那么问题来了:如果页面上有多个text属性的文本一样,怎么办?

2.xpath语法里面*是代表匹配任意的值,在selenium里面*是匹配任意标签,appium里的*是匹配任意class名称,如果几个文本的class属性不一样,就可以通过以下组合:

//android.widget.TextView[@text='小说']

参考代码

# coding:utf-8
from appium import webdriver
from time import sleep
desired_caps = {
                'platformName': 'Android',
                'deviceName': '127.0.0.1:62001',
                'platformVersion': '4.4.2',
                'appPackage': 'com.baidu.yuedu',
                'appActivity': 'com.baidu.yuedu.splash.SplashActivity'
                }
driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub', desired_caps)

# 获取当前界面activity
ac = driver.current_activity
print(ac)

# 等主页面activity出现
driver.wait_activity(".base.ui.MainActivity", 10)

# 点'知道了'
driver.find_element_by_id("com.baidu.yuedu:id/positive").click()

sleep(2)
# 定位页面上text属性
# driver.find_element_by_name("小说").click()  # V1.5以后版本不支持name定位了
driver.find_element_by_xpath("//*[@text='小说']").click()

在学习过程中有遇到疑问的,可以appium+python QQ群交流:330467341

posted @   上海-悠悠  阅读(2369)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示