Selenium 设置元素等待的三种方式详解

Selenium 设置元素等待的三种方式

1. sleep 强制等待
2. implicitly_wait() 隐性等待
3. WebDriverWait() 显示等待

三种方式的优缺点

sleep 强制等待

from selenium import webdriver
from time import sleep
driver = webdriver.Chrome()
sleep(2)        #设置等待2秒钟
driver.get('http://www.baidu.com')
  • 优点: 代码简介,简单明了
  • 缺点:如果设置sleep等待时间过短,元素还没加载出来,程序报错,sleep设置等待时间过长,元素早就加载出来了,程序还在等待,浪费是时间,影响代码整体的运行效率
  • 个人看法: 简单粗暴,根据网站的响应速度和自己的网速来设置合理的休眠时间

implicitly_wait() 隐性等待

from selenium import webdriver
from time import sleep
driver = webdriver.Chrome()
driver.implicitly_wait(20)  #设置等待20秒钟
driver.get('http://www.baidu.com')
  • 优点:

1.代码简介
2.在代码前部分加implicitly_wait(10) ,整个的程序运行过程中都会有效(作用于全局,直接在初始化driver的后面加,后面的代码都会受影响),都会等待元素加载完成
3.在设置的时间内没有加载到整个页面,则会报NosuchElementError。如果元素在第10s被加载出来,自动执行下面的脚本,不会一直等待10s

  • 缺点:
  1. 非要加载到整个页面才执行代码,这样影响代码的执行效率,一般情况下,我们想要的结果是只需加载到了我要定位的元素就执行代码,不需要等待整个页面的完全加载出来再执行代码。
  • 个人看法:

1.不适合用在数据在ajax的网站中,比如翻页什么的,某个元素一直存在,但是数据一直在变,这样的话只要加载出来第一页,后面翻页的数据全部会和第一页的数据相同,因为代码判断了这个元素已经被加载出来了,不会等ajax去加载

WebDriverWait()显示等待

from selenium import webdriver
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.ui import WebDriverWait       #WebDriverWait注意大小写
from selenium.webdriver.common.by import By
driver = webdriver.Chrome()
driver.get('http://www.baidu.com')
try:
    element = 
    WebDriverWait(driver,10).until(EC.presence_of_element_located((By.ID,'kw')))
    element.send_keys('123')
    driver.find_element_by_id('su').click()
except Exception as message:
   print('元素定位报错%s'%message)
finally:
   pass
  • 优点:

代码执行效率快。无需等待整个页面加载完成,只需加载到你要定位的元素就可以执行代码。是最智能的设置元素等待的方式。

  • 缺点:

1.要导入
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.common.by import By
必须要导入以上3个包,导包路径相当的复杂,啰嗦而且麻烦
2.写等待时间的代码也是复杂。步骤稍微有点多。
element=WebDriverWait(driver,10).until(EC.presence_of_element_located((By.ID,‘kw’)))
element.send_keys(‘123’)

  • 个人看法:

相比于两种,这种方式可以算的上好的了,但是就是麻烦,写的代码太多,使用的话可以和第一种方式sleep混合使用,不过我还是喜欢用sleep,本身使用selenium就是没办法破开网站,或者使用selenium比直接破解的方式更好才使用这种,我个人是能不用就不用,抓取速度太慢了。

————————————————
原文链接:https://blog.csdn.net/Gscsd_T/article/details/102837046

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用 PythonSelenium 进行自动化测试时,有时候需要等待页面元素加载完毕才能进行下一步操作,否则可能会出现找不到元素或者元素还没有加载完全的情况。下面介绍三种设置元素等待的方法。 1. 隐式等待 隐式等待设置一个全局等待时间,当查找元素时如果未能立即找到则会等待一段时间,直到超时为止。这种等待方式在整个测试过程中都有效,比较方便。 示例代码: ```python from selenium import webdriver driver = webdriver.Chrome() driver.implicitly_wait(10) # 隐式等待10秒 # 接下来的操作,在元素加载完毕前最多等待10秒 ``` 2. 显式等待 显式等待是指在代码中指定等待条件,当满足条件时才进行下一步操作。这种等待方式更加灵活,可根据具体场景设置不同的等待条件,比如等待元素可见、可点击、出现在页面中等。 示例代码: ```python from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC driver = webdriver.Chrome() wait = WebDriverWait(driver, 10) # 显式等待10秒 # 等待元素可见 element = wait.until(EC.visibility_of_element_located((By.ID, 'myId'))) # 等待元素可点击 element = wait.until(EC.element_to_be_clickable((By.XPATH, '//button[text()="Click Me"]'))) ``` 3. sleep 等待 sleep 是最简单的等待方式,它会暂停当前线程指定的时间,不管页面元素是否已经加载完毕。这种等待方式不太灵活,如果页面元素加载时间较长,可能会导致等待时间不够,从而出现找不到元素的情况。 示例代码: ```python from selenium import webdriver import time driver = webdriver.Chrome() # 等待3秒 time.sleep(3) # 接下来的操作,在元素加载完毕前最多等待3秒 ``` 以上三种等待方式,根据实际情况选择合适的方式即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值