zoukankan      html  css  js  c++  java
  • Selenium之显式、隐式等待

    selenium自动化页面元素存在异常发生的原因有以下几点:

         ① 页面加载时间过慢,需要查找的元素程序已经完成,但是页面还未加载成功。此时可以加载页面等待时间。

         ② 查找的元素没有在当前的iframe或者frame中。此时需要切换会对应的iframe或者frame中才行。

         ③ 元素错误。

    解决页面加载时间所引起的元素找不到,可以为页面设置加载时间。时间的设置分为以下三种:

         1、显示等待   WebDriverWait()

         2、隐式等待   implicitly_wait()

         3、强制等待  sleep()

    WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None)

    说明: driver   -----  WebDriver的驱动程序

              timeout  ------ 最长超时时间,以秒为单位

              poll_frequency   ------- 休眠时间的间隔(步长)时间,默认为0.5秒

              ignored_exceptions  -------  超时后的异常信息,默认情况下抛NoSuchElementException异常

    例如:

             WebDriverWait(driver, 10).until(lambda driver:driver.findElement(By.Id("someId")));

             每隔0.5秒扫描一次检查是否有id为somdld的元素,10秒后没找到就不找了,抛异常。

    简单代码实现:

            import  time 

            from selenium import webdriver

            from selenium.webdriver.support.wait import WebDriver

            driver = webdriver.Chrome()

            driver.get("http://www.baidu.com")

            element = WebDriverWait(driver, 10).until(lambda driver:driver.find_element_by_id("kw"))

            element.send_keys("selenium")

            # 添加智能等待

            driver.implicitly_wait(30)

            driver.find_element_by_id('su').click()

            time.sleep()

            driver.quit()        

  • 相关阅读:
    HTML实体符号代码速查表
    在vue中使用css预编辑器
    多个SVG图形集成到一个SVG图形上
    CSS3那些不为人知的高级属性
    如何搭建一个vue项目(完整步骤)
    Vue.js——vue-resource全攻略
    this.$router.push、replace、go的区别
    Vue界面中关于APP端回调方法问题
    Vue、webpack中默认的config.js、index.js 配置详情
    vue mint ui 手册文档
  • 原文地址:https://www.cnblogs.com/peipei-Study/p/11975253.html
Copyright © 2011-2022 走看看