一、sleep强制等待
1. 导入的模块
- from time import sleep
2. 使用方式
- sleep(seconds)
seconds:等待的时间,单位秒
3. 功能和缺点
功能:强制等待seconds秒后,才可执行下一步操作;
缺点:等待的时间不易确定。若还未到达设置时间,元素加载完成,则需继续等待,直接等待时间结束,才可进行下一步操作(造成时间浪费);若到达设置时间,元素还未加载完成,则会直接报错。
from selenium import webdriver
from time import sleep
def sleep_operate():
"""强制等待sleep"""
driver = webdriver.Chrome()
driver.get("http://www.baidu.com")
sleep(1)
driver.find_element_by_name("tj_trnews").click()
sleep(5)
driver.quit()
二、implicitly_wait隐性等待
1. 使用方式
- driver.implicitly_wait(time_to_wait)
time_to_wait:隐性等待的最长时间,单位秒
2. 功能和缺点
功能:隐性等待time_to_wait时间。
缺点:若还未到达设置时间,元素加载完成,则直接执行下一步,无需继续等待;若到达设置时间,元素还未加载完成,则会直接报错。
优点:此方法的设置是全局的,即每个会话每次仅需调用一次此方法即可。故一般在程序的开头设置此等待。
from selenium import webdriver
def implicitly_wait_operate():
"""隐性等待implicitly_wait"""
driver = webdriver.Chrome()
driver.implicitly_wait(5)
driver.get("http://www.baidu.com")
driver.find_element_by_name("tj_trnews").click()
driver.quit()
三、WebDriverWait显性等待
1. 导入模块
- from selenium.webdriver.support.ui import WebDriverWait
2. WebDriverWait构造函数
- WebDriverWait(driver, timeout, poll_frequency=POLL_FREQUENCY, ignored_exceptions=None)
driver:WebDriver实例
timeout:设置的超时时间,单位秒
poll_frequency:循环查询的时间间隙,单位秒,默认为0.5秒
ignored_exceptions:忽略的异常,默认为NoSuchElementException
返回值为WebDriverWait类
3. WebDriverWait的方法
until(method, message=''):判断元素是否存在
每poll_frequency秒就检查待测试的元素是否可见,若可见,则无需等待网页加载完成即可直接跳出等待,执行下一步;若达到timeout仍不可见,则报TimeoutException错。
method:调用该方法提供的程序作为一个参数,直到返回值为True;
message:报错时输出的信息;until_not(method, message=''):判断元素是否消失
每poll_frequency秒就检查待测试的元素是否不可见,若不可见,则无需等待网页加载完成即可直接跳出等待,执行下一步;若达到timeout仍可见,则报TimeoutException错。
method:调用该方法提供的程序作为一个参数,直到返回值为False;
message:报错时输出的信息;
注:method参数一般需结合expected_conditions 模块来使用
from selenium import webdriver
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions
from selenium.webdriver.common.by import By
def WebDriverWait_operate():
"""显性等待"""
# https://blog.csdn.net/JDMXI/article/details/83097491
# https://blog.csdn.net/You77/article/details/56289613
driver = webdriver.Chrome()
driver.get("http://www.baidu.com")
driver_wait = WebDriverWait(driver, 5)
# 判断百度界面的hao123是否存在
try:
# <a href="https://www.hao123.com" name="tj_trhao123" class="mnav">hao123</a>
condition = expected_conditions.presence_of_element_located((By.NAME, 'tj_trhao123'))
driver_wait.until(condition, "hao123链接不存在")
driver.find_element_by_name("tj_trhao123").click()
except:
print("未找到hao123链接")
driver.quit()