强制等待:sleep()
import time
sleep(5) #等待5秒
- 设置固定休眠时间,单位为秒。 由python的
time
包提供, 导入 time 包后就可以使用。 缺点:
不智能,使用太多的sleep会影响脚本运行速度。
隐式等待:implicitly_wait()
driver.implicitly_wait(10) #隐式等待10秒
- 由webdriver提供的方法,一旦设置,这个隐式等待会在WebDriver对象实例的整个生命周期起作用,它不针对某一个元素,是全局元素等待,即在定位元素时,需要等待页面全部元素加载完成,才会执行下一个语句。如果超出了设置时间的则抛出异常。
缺点:
当页面某些js无法加载,但是想找的元素已经出来了,它还是会继续等待,直到页面加载完成(浏览器标签左上角圈圈不再转),才会执行下一句。某些情况下会影响脚本执行速度。
显示等待:WebDriverWait()
需要通过from selenium.webdriver.support.wait import WebDriverWait
导入模块
WebDriverWait(driver,timeout,poll_frequency=0.5,ignored_exceptions=None)
- driver:浏览器驱动
- timeout:最长超时时间,默认以秒为单位
- poll_frequency:检测的间隔步长,默认为0.5s
- ignored_exceptions:超时后的抛出的异常信息,默认抛出NoSuchElementExeception异常。
# WebDriverWait(driver,timeout=程序等待时间,poll_frequency=每隔几秒执行until中的方法).until(method='具体来做什么事情')
# poll_frequency默认为0.5s
#这个函数和def locator()效果一样都是为了定位元素,只是加了时间限制,显示等待,传参:by直接传入By.ID的属性值“id”就好,无需导入By类
def get_element(self, by, path):
try:
element = WebDriverWait(self.driver, 10).until(lambda x: x.find_element(by=by, value=path))
return element
except Exception as e:
raise e
Lambda函数是匿名函数。
Lambda函数可以接受任意数量的参数,但只能具有一个表达式。
语法
lambda arguments : expression
执行表达式并返回结果
#a是参数,a+10是表达式
x = lambda a : a + 10
print(x(5))
执行结果
15