原文:https://huilansame.github.io/huilansame.github.io/archivers/sleep-implicitlywait-wait
该文章主要讲解了selenium的三种等待方式;在定位元素的时候定位不到可能就是:
1.有frame
2.没有加等待时间
为什么要加等待时间了,是因为代码运行速度与浏览器加载速度不一样,导致代码运行完了浏览器还没有加载完,出现异常情况。
下面讲解selenium的三种等待方式:
1.强制等待,是最简单粗暴的方法slepp(xx),不管你浏览器是否加载完了,程序都得等待xx秒,xx秒一到,继续执行下面的代码,一般作为调试的时候使用
# -*- coding: utf-8 -*-
from selenium import webdriver
from time import sleep
driver = webdriver.Firefox()
driver.get('https://huilansame.github.io')
sleep(3) # 强制等待3秒再执行下一步
print driver.current_url
driver.quit()
2.隐形等待,是设置了一个最长等待时间,如果在规定时间内整个网页加载完成,则执行下一步,否则一直等到时间截止,然后执行下一步
# -*- coding: utf-8 -*-
from selenium import webdriver
driver = webdriver.Firefox()
driver.implicitly_wait(30) # 隐性等待,最长等30秒
driver.get('https://huilansame.github.io')
print driver.current_url
driver.quit()
3.显示等待,程序每隔xx秒看一眼,如果条件成立了,则执行下一步,否则继续等待,直到超过设置的最长时间,然后抛出TimeoutException。
# -*- coding: utf-8 -*-
from selenium import webdriver
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.common.by import By
driver = webdriver.Firefox()
driver.implicitly_wait(10) # 隐性等待和显性等待可以同时用,但要注意:等待的最长时间取两者之中的大者
driver.get('https://huilansame.github.io')
locator = (By.LINK_TEXT, 'CSDN')
try:
WebDriverWait(driver, 20, 0.5).until(EC.presence_of_element_located(locator))
print driver.find_element_by_link_text('CSDN').get_attribute('href')
finally:
driver.close()
注意的是:最长的等待时间取决于两者之间的大者,此例中为20,如果隐性等待时间 > 显性等待时间,则该句代码的最长等待时间等于隐性等待时间。
WebDriverWait(driver, 超时时长, 调用频率, 忽略异常).until(可执行方法, 超时时返回的信息)