java使用selenium自动化WebDriver等待的示例代码

 更新时间:2023年09月19日 14:28:02   作者:月丨曦  
显式等待和隐式等待是WebDriver中两种常用的等待方式,它们都可以用来等待特定的条件满足后再继续执行代码,本文给大家介绍java使用selenium自动化WebDriver等待,感兴趣的朋友一起看看吧

java使用selenium自动化WebDriver等待

显式等待和隐式等待是WebDriver中两种常用的等待方式,它们都可以用来等待特定的条件满足后再继续执行代码。

1.显式等待(Explicit Wait):使用WebDriverWait类来实现,可以根据特定条件等待元素出现、可见、可点击等。

示例代码:

WebDriverWait wait = new WebDriverWait(driver, 10);
WebElement element = wait.until(ExpectedConditions.visibilityOfElementLocated(By.id("exampleId")));
// 等待元素出现并可见后,继续执行下一行代码

通过 ExpectedConditions 类提供的方法,可以等待元素的可见性、可点击性、存在等不同条件。

2.隐式等待(Implicit Wait):使用 driver.manage().timeouts().implicitlyWait() 方法来设置等待的超时时间,然后在查找元素时会等待指定的时间,如果在超时时间内找到了元素,则继续执行下一行代码,否则抛出 NoSuchElementException 异常。

示例代码:

driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);
WebElement element = driver.findElement(By.id("exampleId"));
// 等待10秒内找到元素,如果超时未找到则抛出异常

隐式等待适用于整个WebDriver会话的生命周期,只需要设置一次,然后在之后的查找元素中会自动等待指定的时间。

补充:Selenium:三种等待方式

UI自动化测试,大多都是通过定位页面元素来模拟实际的生产场景操作。但在编写自动化测试脚本中,经常出现元素定位不到的情况,究其原因,无非两种情况:1、有frame;2、没有设置等待。

因为代码运行速度和浏览器加载渲染速度,不是一个量级,所以导致了这种情况发生。webdriver提供了3种类型的等待:显式等待、隐式等待、强制等待。

一、显示等待

定义:等待某个条件成立时继续执行,否则在达到最大时长时抛出异常(TimeoutException);

WebDriverWait类是由webdriver提供的等待方法,配合该类提供的until()和until_not()方法一起使用,就可以根据判断条件而灵活进行等待,格式如下

  • WebDriverWait(driver,timeout,poll_frequency=0.5,ignored_exceptions=None)
  • driver:浏览器驱动
  • timeout:最长超时时间
  • poll_frequency:检测间隔时间,默认0.5s
  • ignored_exceptions:超时后的异常信息,默认情况抛出NoSuchElementException异常
  • WebDriverWait()一般由until()或until_not方法配合使用,下面是这两种方法的说明:
  • until(method,message=''):调用该方法提供的驱动程序作为一个参数,直到返回值为True;
  • until_not(method,message=''):调用该方法提供的驱动程序作为一个参数,直到返回值为Flase;

示例代码如下:

  # 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.Chrome("F:\安装工具\python\chromedriver.exe")
  driver.implicitly_wait(10)
  driver.get('http://www.cnblogs.com/imyalost/')
 locator = (By.LINK_TEXT, '老_张')
 try:
     WebDriverWait(driver, 20, 0.5).until(EC.presence_of_element_located(locator))
     print(driver.find_element_by_link_text('老_张').get_attribute('href'))
 finally:
     driver.close()

代码解析:

本例中,通过as关键字将expected_conditions重命名为EC,并调用presence_of_element_located()方法判断元素是否存在;

上面的例子中,同时使用了隐性等待和显性等待,但是需要注意的是:等待的最长时间取两者之中的最大值;

expected_conditions类提供的预期条件判断方法如下:

  • title_is: 判断当前页面的title是否完全等于(==)预期字符串,返回布尔值
  • title_contains : 判断当前页面的title是否包含预期字符串,返回布尔值
  • presence_of_element_located : 判断某个元素是否被加到了dom树里,并不代表该元素一定可见 4 visibility_of_element_located : 判断某个元素是否可见. 可见代表元素非隐藏,并且元素的宽和高都不等于0
  • visibility_of : 跟上面的方法做一样的事情,只是上面的方法要传入locator,这个方法直接传定位到的element就好了  presence_of_all_elements_located : 判断是否至少有1个元素存在于dom树中。举个例子,如果页面上有n个元素的class都是‘column-md-3‘,那么只要有1个元素存在,这个方法就返回True
  • text_to_be_present_in_element : 判断某个元素中的text是否 包含 了预期的字符串
  • text_to_be_present_in_element_value : 判断某个元素中的value属性是否 包含 了预期的字符串
  • frame_to_be_available_and_switch_to_it : 判断该frame是否可以switch进去,如果可以的话,返回True并且switch进去,否则返回False
  • invisibility_of_element_located : 判断某个元素中是否不存在于dom树或不可见
  • element_to_be_clickable : 判断某个元素中是否可见并且是enable的,这样的话才叫clickable
  • staleness_of : 等某个元素从dom树中移除,注意,这个方法也是返回True或False
  • element_to_be_selected : 判断某个元素是否被选中了,一般用在下拉列表
  • element_selection_state_to_be : 判断某个元素的选中状态是否符合预期
  • element_located_selection_state_to_be : 跟上面的方法作用一样,只是上面的方法传入定位到的element,而这个方法传入locator
  • alert_is_present : 判断页面上是否存在alert

二、隐式等待

定义:通过设定的时长等待页面元素加载完成,再执行下面的代码,如果超过设定时间还未加载完成,则继续执行下面的代码(注意:在设定时间内加载完成则立即执行下面的代码);

隐式等待的方法为:implicitly_wait,示例代码如下:

 # coding = utf-8
 from selenium import webdriver
 driver = webdriver.Chrome("F:\安装工具\python\chromedriver.exe")
 driver.implicitly_wait(10) # 隐性等待,最长等10秒
 driver.get('http://www.cnblogs.com/imyalost/')
 print(driver.current_url)
 driver.quit()

代码解析:

本例中,设置的等待时长为10秒,但这10秒并非一个固定时间,并不影响脚本执行速度;其次,隐式等待对整个driver的周期都起作用,因此只需要设置一次即可。

三、强制等待

即sleep()方法,由python中的time模块提供,强制让代码等待xxx时间,无论前面的代码是否执行完成或者还未完成,都必须等待设定的时间。

示例代码如下:

  # coding = utf-8
  from selenium import webdriver
  from time import sleep
  driver = webdriver.Chrome("F:\安装工具\python\chromedriver.exe")
  driver.get('http://www.cnblogs.com/imyalost/')
  sleep(5)
 print(driver.current_url)
 driver.quit()

代码解析:

本例中,设置强制等待时间为5秒,5秒之后,打印获取到的当前页面的url,然后关闭窗口。

这种强制等待的方法,在debug时候很有用,不过建议慎用这种方法,因为太死板,严重影响程序执行速度!

以上三种等待方法,在具体的场景中需要根据情况选择合适的方法,灵活运用。。。

到此这篇关于java使用selenium自动化WebDriver等待的文章就介绍到这了,更多相关java selenium自动化WebDriver等待内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java将集合List转换成String字符串(或String转换成List)详解

    Java将集合List转换成String字符串(或String转换成List)详解

    今天在写项目的时候遇到一个问题,就是要把得到的一个集合转换成字符串,下面这篇文章主要给大家介绍了关于Java将集合List转换成String字符串(或String转换成List)的相关资料,需要的朋友可以参考下
    2023-06-06
  • logback-spring.xml配置详解

    logback-spring.xml配置详解

    这篇文章主要介绍了logback-spring.xml详解,本文介绍了logback-spring.xml相关的知识与概念,结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • 你肯定能看懂的Java IO相关知识总结

    你肯定能看懂的Java IO相关知识总结

    群里有大佬说想让我写一篇NIO,一直也没写,但是和同事聊天也说对Java的IO不是很清晰,因此今天就写下Java的io,先打个基础,下次写NIO,需要的朋友可以参考下
    2021-05-05
  • 解决Swagger2返回map复杂结构不能解析的问题

    解决Swagger2返回map复杂结构不能解析的问题

    这篇文章主要介绍了解决Swagger2返回map复杂结构不能解析的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • Java死锁_动力节点Java学院整理

    Java死锁_动力节点Java学院整理

    死锁是两个甚至多个线程被永久阻塞时的一种运行局面,这种局面的生成伴随着至少两个线程和两个或者多个资源。在这里我已写好一个简单的程序,它将会引起死锁方案然后我们就会明白如何分析它
    2017-06-06
  • springcloud ribbon 饥饿加载原理解析

    springcloud ribbon 饥饿加载原理解析

    这篇文章主要介绍了springcloud ribbon 饥饿加载原理解析,饥饿加载特别适用于对启动性能要求较高的场景,如系统启动初期就有高并发请求的情况,感兴趣的朋友跟随小编一起学习吧
    2024-04-04
  • SpringBoot结合Tess4J实现拍图识字的示例代码

    SpringBoot结合Tess4J实现拍图识字的示例代码

    图片中的文字提取已经越来越多地应用于数据输入和自动化处理过程,本文主要介绍了SpringBoot结合Tess4J实现拍图识字的示例代码,具有一定的参考价值,感兴趣的可以了解一下
    2024-06-06
  • Java消息队列RabbitMQ入门详解

    Java消息队列RabbitMQ入门详解

    这篇文章主要介绍了Java消息队列RabbitMQ入门详解,RabbitMQ是使用Erlang语言开发的开源消息队列系统,基于AMQP协议 来实现,AMQP的主要特征是面向消息、队列、路由(包括点对点和发布 /订阅)、可靠性、安全,需要的朋友可以参考下
    2023-07-07
  • SpringBoot各种注解详解

    SpringBoot各种注解详解

    SpringBoot的一个核心功能是IOC,就是将Bean初始化加载到容器中,Bean是如何加载到容器的,可以使用SpringBoot注解方式或者Spring XML配置方式。SpringBoot注解方式减少了配置文件内容,更加便于管理,并且使用注解可以大大提高了开发效率
    2022-12-12
  • java String源码和String常量池的全面解析

    java String源码和String常量池的全面解析

    下面小编就为大家分享一篇java String源码和String常量池的全面解析,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12

最新评论