在自动化脚本中我们打开指定网址后,为了防止页面报错我们一般强制让页面sleep1s。但是这样固定的等待时间会导致我们测试用例执行加长,本篇主要就等待web元素的出现的两种用法进行展开,包括隐式等待和显示等待。
隐式等待(driver.implicitly_wait())
1)概述:全局的设定,后面所有的选择元素的代码都不需要单独的指定周期性的等待
2)格式:driver.implicitly_wait(5)
3)解释:执行了driver.implicitly_wait(5) 这段代码之后,后面任何选择元素操作,最多可以等待5s。若元素未找到会每隔0.5s执行一次直到超出最大等待时间。
4)注意:隐式等待只能保证找到元素,但是并不能找到所有元素。此时可以选择强制sleep让页面完全刷新出来
from selenium import webdriver driver=webdriver.Chrome() #隐式等待:设置最大等待时间5s,作用于整个webdriver driver.implicitly_wait(5)
显示等待
1)引入:如果有一个特殊的操作需要等待30s,其余操作5s内均可做出响应。应该如何做呢?
2)概述:为一个操作专门指定等待时间(针对具体的操作)
方法1: from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC from selenium.webdriver.common.by import By ele = WebDriverWait(driver, 60).until(EC.presence_of_element_located((By.ID,'1')))#60s 不用强记,需要使用的时候直接拷贝,修改后面的元素值即可**((By.ID,'1'))**
方法2::先用临时隐式等待改为60秒,等操作结束之后再改为5秒 from selenium import webdriver driver=webdriver.Chrome() driver.implicitly_wait(5) driver.get('http://www.baidu.com') ele=driver.find_element_by_id('kw') ele.send_keys('python百度百科') button=driver.find_element_by_id('su') button.click() #**********耗时操作开始#********** driver.implicitly_wait(60) res=driver.find_element_by_id('1') connent = res.text if res.text.startswith('Python是一种计算机程序设计语言') : print('测试通过') else: print('测试失败') print(connent) #**********耗时操作结束#********** driver.implicitly_wait(5)
参考链接:https://www.jianshu.com/p/1ec2f6052397