ebelement类的方法,常用的汇总如下:
clear()清空 例如登录时先清空输入框中的内容
driver.find_element_by_id('username').clear()
click(),单击 例如点击登录按钮
driver.find_element_by_id('submit').click()
get_attribute()获取元素属性的值
zhi=driver.find_element_by_id('su').get_attribute('type')获取百度首页,“百度一下”的属性type的值,运行结果为“submit”
is_enabled()元素是否可编辑, 返回值为布尔
driver.get('https://www.baidu.com/')
zhi=driver.find_element_by_id('su')
print zhi.is_enabled()
运行结果为True
is_displayed() 元素是否可见,返回布尔
confirmPayment = WebDriverWait(currentDr,5).until(lambda x:x.find_element_by_class_name("event-pay"))
if confirmPayment.is_displayed():
confirmPayment.click()
is_selected() 元素是否选中,返回布尔
driver.find_element_by_id('s1_2').is_selected() 返回false
以下转载至:https://www.jb51.net/article/92672.htm
1. 强制等待
sleep(xx),最简单粗暴,就是强制等待xx时间
2、隐性等待
driver.implicitly_wait(
30
)
# 隐性等待,最长等30秒
隐形等待是设置了一个最长等待时间,如果在规定时间内网页加载完成,则执行下一步,否则一直等到时间截止,然后执行下一步。注意这里有一个弊端,那就是程序会一直等待整个页面加载完成,也就是一般情况下你看到浏览器标签栏那个小圈不再转,才会执行下一步,但有时候页面想要的元素早就在加载完成了,但是因为个别js之类的东西特别慢,我仍得等到页面全部完成才能执行下一步。
一旦设置了隐式等待,则它存在整个 WebDriver 对象实例的声明周期中,隐式的等到会让一个正常响应的应用的测试变慢,它将会在寻找每个元素的时候都进行等待,这样会增加整个测试执行的时间。
ps:隐性等待对整个driver的周期都起作用,所以只要设置一次即可,不要当成是sleep(),到一个地方使用一次
3、显性等待
WebDriverWait(self,driver,timeout,poll_frequency=POLL_FREQUENCY,ignored_exceptions=None).until(self,method,message=)
或者
WebDriverWait(self,driver,timeout,poll_frequency=POLL_FREQUENCY,ignored_exceptions=None).until_not(self,method,message=)
self, 函数本身,在实际使用的时候不需要输入
driver, webdriver的驱动程序,如(IE、FireFox、chrome、safari等)
timeout,超时时间,默认以秒为单位
poll_frequency,休眠时间(步长)的间隔,默认为0.5秒,即检测元素是否存在的频率
ignored_exceptions, 忽略的异常,如果在调用until或until_not的过程中抛出这个元组中的异常,则不中断代码,继续等待,如果抛出的是这个元组外的异常,则中断代码,抛出异常。默认只有NoSuchElementException
WebDriverWait一般由until或until_not配合使用
until(method,message=")当某元素出现或什么条件成立则继续执行,直到返回值不为False
until_not(method,message=")是当某元素消失或什么条件不成立则继续执行,直到返回值为False
method: 在等待期间,每隔一段时间调用这个传入的方法,直到返回值不是False
message: 如果超时,抛出TimeoutException,将message传入异常
ps:隐性等待和显性等待可以同时用,但要注意:等待的最长时间取两者之中的大者
WebDriverWait(currentDr, 20, 0.5).until(EC.presence_of_element_located(locator))
WebDriverWait(currentDr,5).until(lambda x:x.find_element_by_class_name("kw"))
下面是个人见解:
隐性等待地址栏上的加载动画完成,使命就结束了,并不能代替强制等待sleep,举个自己遇到的例子,页面打开登录后地址栏上的缓冲动画在转圈,但是页面上菜单已经加载了,使用显性等待的方法,点击了菜单,这时候地址栏上的缓冲动画结束了,但是点击菜单后页面上的元素没有加载出来,这时候如果定位元素,会提示“无法确定加载状态”的错误,无法定位,想定位元素,还是得用强制等待 或者 使用显性等待的方法,所以个人认为,隐形等待在打开新页面时能发挥作用,但是定位元素还是显性等待的方法更好