selenium等待元素出现

在自动化脚本中我们打开指定网址后,为了防止页面报错我们一般强制让页面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

posted @ 2020-10-28 19:54  HkGov  阅读(3518)  评论(0编辑  收藏  举报