关于新版本selenium定位元素报错:‘WebDriver‘ object has no attribute ‘find_element_by_id‘等问题 Posted 2023-04-06 热爱学习的猪
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于新版本selenium定位元素报错:‘WebDriver‘ object has no attribute ‘find_element_by_id‘等问题相关的知识,希望对你有一定的参考价值。
由于一段时间没有使用Selenium,当再次使用时发现之前写的Selenium元素定位的代码运行之后会报错,发现是Selenium更新到新版本(4.x版本)后,以前的一些常用的代码的语法发生了改变,当然如果没有更新过或是下载最新版本的Selenium是不受到影响的,还可以使用以前的写法。接下来就是讨论有关于新版本后Selenium定位元素代码的新语法。
改动一:executable_path
旧版本Selenium代码:
from selenium import webdriver
driver= webdriver. Chrome( executable_path= '/home/yan/Python/chromeselenium/chromeselenium/chromedriver' )
executable_path是我们Selenium驱动的存放路径,只有使用executable_path指定出该路径,Selenium才能正常工作,但是Selenium经过版本更新之后,在使用如上写法时,系统就会报错executable_path has been deprecated, please pass in a Service object,如下所示:
DeprecationWarning: executable_path has been deprecated, please pass in a Service object
driver = webdriver. Chrome( executable_path= "/home/yan/Python/chromeselenium/chromeselenium/chromedriver" )
意思是:executable_path已被弃用,请传入一个Service对象,于是我们就需要修改为如下代码:
新版本Selenium代码:
from selenium import webdriver
from selenium. webdriver. chrome. service import Service
service = Service( executable_path= '/home/yan/Python/chromeselenium/chromeselenium/chromedriver' )
driver = webdriver. Chrome( service= service)
driver. get( "网址" )
改动二:Selenium定位元素代码
在旧版本中,我们大多数都是使用以下代码来进行元素的定位 旧版本Selenium元素定位代码:
inputTag = driver. find_element_by_id( "value" )
inputTags = driver. find_element_by_class_name( "value" )
inputTag = driver. find_element_by_name( "value" )
inputTag = driver. find_element_by_tag_name( "value" )
inputTag = driver. find_element_by_xpath( "value" )
inputTag = driver. find_element_by_css_selector( "value" )
在版本没有更新前我们使用的都是driver.find_element_by_方法名(”value”) ,方法名就是by_id、by_class_name、by_name等等,而"value",则是传入的值 ,以百度搜索框为例,右键点击百度搜索框点击检查则可看其html 源代码中属性id=”kw“ ,以旧版本的写法使用id值查找搜索框应该是:
inputTag = driver. find_element_by_id( "kw" )
在版本没有更新之前,通常情况下运行都是能够正确定位到对应的元素,但是Selenium经过版本升级之后,运行后会报错,以driver.find_element_by_id(“value”)为例(其他报错也是类似下面的报错信息),运行后会报错,如下:
根据官方最新文档,将代码进行修改,修改后的格式由 driver.find_element_by_方法名(”value”)变为 driver.find_element(By.方法名, “value”) ,具体改动如下:
新版本Selenium代码: 首先在文件头部引入如下代码
from selenium. webdriver. common. by import By
而后做如下修改:
inputTag = driver. find_element( By. ID, "value" )
inputTag = driver. find_element( By. CLASS_NAME, "value" )
inputTag = driver. find_element( By. NAME, "value" )
inputTag = driver. find_element( By. TAG_NAME, "value" )
inputTag = driver. find_element( By. XPATH, "value" )
inputTag = driver. find_element( By. CSS_SELETOR, "value" )
修改完之后即可使用selenium进行自动化工作!
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
以上是关于关于新版本selenium定位元素报错:‘WebDriver‘ object has no attribute ‘find_element_by_id‘等问题的主要内容,如果未能解决你的问题,请参考以下文章
selenium+Python页面元素定位问题
appium+python自动化28-name定位
Python selenium PO By.XPATH定位元素报错
Python+Selenium定位悬停元素总是报错,啥原因
selenium02-元素无法定位解决办法(简单)
一个关于Selenium元素定位多个元素的问题