Selenium - 元素等待(2) - 显式等待/EC等待
Selenium - 元素等待
显式等待
显式等待是一种灵活的等待方式,需要声明等待的结束条件,当满足条件时会自动结束等待;
需要引入
WebDriverWait包以及exception_conditions,wait方法配合ec的until或者until_not;可以实现针对于某一个元素等待,每经过多少秒就查看一次元素是否可见;
如果可见就停止等待;
如果不可见就继续等待直到超过规定的时间后,报超时异常;
WebDriverWait:声明需要等待的条件,可以设置为元素显示后;until():直到条件成立返回为真,等待结束。如果超时,抛出TimeoutException,将message传入异常。until_not():直到条件不成立返回为真,是当某元素消失或什么条件不成立则继续执行,等待结束。如果超时,抛出TimeoutException,将message传入异常。expected_conditions:是selenium的一个模块,其中包含一系列可用于判断的条件方法。
# 导入显示等待函数
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
driver = webdriver.Chrome()
driver.get('http://www.baidu.com')
driver.find_element_by_id('kw').send_keys('python')
driver.find_element_by_id('su').click()
# 设置等待15秒,等待浏览器标题为python_百度搜索,结束等待,继续运行;
WebDriverWait(driver, 15).until(EC.title_is('python_百度搜索'))
# 设置等待8秒,等待浏览器标题不为selenium后,结束等待,继续运行;
WebDriverWait(driver, 8).until_bot(EC.title_is('selenium'))
print(driver.title)
driver.quit()
EC等待场景
介绍
EC 全称为
expected_conditions;是Selenium的一个子模块 ——
selenium.webdriver.support.expected_conditions;可以对网页上元素是否存在,可点击等等进行判断,一般用于断言或与WebDriverWait配合使用;
引用模块
from selenium.webdriver.support import expected_conditions as EC
网页信息
# 判断当前页面的titlt完全等于(==)预期字符(区分大小写);
# 若等于则返回True,不等于返回False;
EC.title_is(value)
# 判断当前页面的titlt包含预期字符(区分大小写);
# 若包含则返回True,不包含返回False;
EC.title_contains(value)
# 判断网页是否为特定网页(必须完全符合),
# 是则返回True,否则返回False
EC.url_to_be(url)
# 判断网页地址完全等于(==)预期字符(区分大小写),
# 若等于则返回True,不等于返回False;
EC.url_changes(url)
# 判断网址地址是否包含特定文本(区分大小写);
# 若包含则返回True,不包含返回False;
EC.url_contains(url)
# 判断网址是否符合特定格式,
# 符合则返回True,不符合则返回False
pattern = r'(https):\/\/[\w\-_]+(\.[\w\-_]+)+([\w\-\.,@?^=%&:/~\+#]*[\w\-\@?^=%&/~\+#])?' #使用正则表达式,规定网址格式(格使要求以https开头)
EC.url_matches(pattern)
文本判断
# 判断给定文本是否出现在特定元素中;
# 若存在则返回True,不存在返回False;
## locator:定位所有class="wd"的元素
from selenium.webdriver.common.by import BY
locator = (By.CLASS_NAME, "wd")
EC.text_to_be_present_in_element(locator, value)
# 判断某文本是否是存在于特定元素的value值中,
# 存在则返回True,不存在则返回False,
## 对于查看没有value值的元素,也会返回False
EC.text_to_be_present_in_element_value(locator, value)
窗口信息
# 判断alert弹窗是否存在;
# 若存在则返回True,不存在返回False;
EC.alert_is_present()
# 判断某个frame是否可以切换过去,
# 若可以则切换到该frame,否则返回False
## locator:XPATH="html/body/iframe"的元素
from selenium.webdriver.common.by import BY
locator = (By.XPATH, "html/body/iframe")
EC.frame_to_be_available_and_switch_to_it(locator)
# 通过是否增加了句柄数量判断是否打开新窗口,
# 有新窗口则返回True,没有新窗口返回False
current_handles = driver.window_handles
EC.new_window_is_opened(current_handles)
# 判断窗口数量是否是特定数值,
# 是该数值则返回True,否则返回False
EC.number_of_windows_to_be(num_windows)
元素状态
# 判断某元祖是否被选中;
# 选中则返回True,未选则返回False;
## locator:定位所有class="wd"的元素
from selenium.webdriver.common.by import BY
locator = (By.CLASS_NAME, "wd")
EC.element_located_to_be_selected(locator)
# 判断某元祖是否与预期相同,
# 相同则返回True,不同则返回False
EC.element_located_selection_state_to_be(locator, BOOLE)
# 判断某元素是否被选中;
# 选中则返回True,未选则返回False;
element = driver.find_element_by_id('kw')
EC.element_to_be_selected(element)
# 判断某元素的选中状态是否与预期相同;
# 相同则返回True,不同则返回False;
EC.element_selection_state_to_be(element, BOOLE)
# 判断某元祖是否可访问并且可启用,比如能够点击;
# 若可以则返回元素本身,否则返回False
from selenium.webdriver.common.by import BY
locator = (By.CLASS_NAME, "wd")
EC.element_to_be_clickable(locator)
# 判断某个元祖是不是不可访问或者不存在在DOM树中;
# 不存在则返回True,存在则返回False
EC.invisibility_of_element_located(locator)
元素可见
# 判断一个元素存在于页面DOM树中;
# 存在则返回元素本身,不存在则报错。
## locator:定位所有class="wd"的元素
from selenium.webdriver.common.by import BY
locator = (By.CLASS_NAME, "wd")
EC.presence_of_element_located(locator)
# 判断定位的元素范围内,至少有一个元素存在于页面当中
# 存在则以list形式返回元素本身,不存在则报错;
EC.presence_of_all_elements_located(locator)
# =============================================================
# 判断特定元素是否存在于DOM树中并且可见,可见意为元素的高和宽都大于0;
# 元素存在返回元素本身,否则返回False;
element = driver.find_element_by_id('kw')
EC.visibility_of(element)
# 判断特定元素是否存在于DOM树中并且可见,可见意为元素的高和宽都大于0;
# 元素存在返回元素本身,否则返回False;
EC.visibility_of_element_located(locator)
# 判断locator定位的所有元素都存在于DOM树中并且可见,可见意为元素高和宽都大于0;
# 存在则以list形式返回元素,否则返回False;
EC.visibility_of_all_elements_located(loccator)
# 判断locator定位的所有元素中,至少有一个存在于DOM树中并且可见,可见意为元素高和宽都大于0;
# 存在则以list形式返回存在的元素,一个元素都不存在的情况下返回空list;
EC.visibility_of_any_elements_located(locator)
注:
presence和visibility有点相像,区别在于:
presence强调元素存在于DOM树中,可见不可见无所谓;(性能上会稍微快一点点)
visibility要求必须高和宽必须都大于0;
Selenium - 元素等待(2) - 显式等待/EC等待的更多相关文章
- selenium—隐式等待和显式等待
一.隐式等待和显式等待的区别 隐式等待:是整个页面的等待.设置一个最长的等待时间,在规定时间内整个页面加载完成,则执行下一步,否则继续等待直到最长等待时间结束. 显式等待:是针对某个元素的等待.在设置 ...
- Selenium系列(六) - 强制等待、隐式等待、显式等待
如果你还想从头学起Selenium,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1680176.html 其次,如果你不懂前端基础知识, ...
- selenium(5)-解读强制等待,隐式等待,显式等待的区别
背景 为什么要设置元素等待 因为,目前大多数Web应用程序都是使用Ajax和Javascript开发的:每次加载一个网页,就会加载各种HTML标签.JS文件 但是,加载肯定有加载顺序,大型网站很难说一 ...
- Selenium4+Python3系列(六) - Selenium的三种等待,强制等待、隐式等待、显式等待
为什么要设置元素等待 直白点说,怕报错,哈哈哈! 肯定有人会说,这也有点太直白了吧. 用一句通俗易懂的话就是:等待元素已被加载完全之后,再去定位该元素,就不会出现定位失败的报错了. 如何避免元素未加载 ...
- selenium的webdriver三种等待方式(显式等待WebDriverWait+implicitly_wait隐式等待+sleep强制等待)
隐式等待是等页面加载,不是等元素!!! 1.显式等待 一个显式等待是你定义的一段代码,用于等待某个条件发生然后再继续执行后续代码.显式等待是等元素加载!!! 2.隐式等待,相当于设置全局的等待,在定位 ...
- “全栈2019”Java多线程第三十二章:显式锁Lock等待唤醒机制详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...
- selenium 隐式等待与显式等待
1.隐式等待:driver.implicitly_wait() driver = webdriver.Chrome()driver.implicitly_wait(10) #获取元素时最多会等 ...
- Selenium+Java(六)Selenium 强制等待、显式等待、隐实等待
前言 在实际测试过程中,由于网速或性能方面的原因,打开相应的网页后或在网页上做了相应的操作,网页上的元素可能不会马上加载出来,这个时候需要在定位元素前等待一下,等元素加载出来后再进行定位,根据实际使用 ...
- 【亲测显式等待】Selenium:元素等待的4种方法
Selenium:元素等待的4种方法 1.使用Thread.sleep(),这是最笨的方法,但有时候也能用到而且很实用. 2.隐式等待,隐性等待是指当要查找元素,而这个元素没有马上出现时,告诉We ...
- 显式等待-----Selenium快速入门(十)
上一篇说了元素定位过程中的隐式等待,今天我们来探讨一下显示等待.显式等待,其实就是在使用WebDriverWait这个对象,进行等待.显式等待对比隐式等待,多了一些人性化的设置,可以说是更细化的隐式等 ...
随机推荐
- [rk3568][buildroot] 移除RK3568 iodomain check
1. 问题背景 RK3568 基线代码默认会起一个服务监控RK3568 iodomain,该服务间隔性输出log信息: 由于该功能非必要,故选择移除该部分逻辑 2.解决方案 查看源码编译脚本,如下图所 ...
- Spring--bean管理(easy)
bean作用范围 利用同一个BookDao设置出来两个不同的对象,得到相同的地址: (默认为单例,即表现为同一个地址) 要是想要得到不同的地址,就需要我们在接口实现类的上面加上这样一个注解:(双例) ...
- 再次打开Spring界面,多处报错
分享一下经历 在我再次打开Srpring之后,打算解决一下"历史遗留问题",发现多处标红(挺崩溃的)! 就比如这句话,刚才就是不亮: 毕竟我上次的应用还是很顺利的,所以也就没有第一 ...
- 如何高效实现 MySQL 与 elasticsearch 的数据同步
MySQL 自身简单.高效.可靠,是又拍云内部使用最广泛的数据库.但是当数据量达到一定程度的时候,对整个 MySQL 的操作会变得非常迟缓.而公司内部 robin/logs 表的数据量已经达到 800 ...
- 63.C++类型转换
类型转换(cast)是将一种数据类型转换成另一种数据类型.例如,如果将一个整型值赋给一个浮点类型的变量,编译器会暗地里将其转换成浮点类型. 转换是非常有用的,但是它也会带来一些问题,比如在转换 ...
- java 环境变量配置详细教程(2023 年全网最详细)
前言: 在上一篇文章中,壹哥给大家重点讲解了 Java 实现跨平台的原理,不知道你现在有没有弄清楚呢?如果你还有疑问,可以在评论区留言- 之前的三篇文章,主要是理论性的内容,其实你暂时跳过不看也是可以 ...
- Condition 接口
系统性学习,移步IT-BLOG Java 对象拥有一组监视方法:wait().wait(long timeout).notify() 以及 notifyAll() 方法,这些方法与 synchroni ...
- 详解DDD:如何避免写流水账代码?
在日常工作中我观察到,面对老系统重构和迁移场景,有大量代码属于流水账代码,通常能看到开发在对外的API接口里直接写业务逻辑代码,或者在一个服务里大量的堆接口,导致业务逻辑实际无法收敛,接口复用性比较差 ...
- CISCN2021-第十四届全国大学生信息安全竞赛-WriteUp
WriteUp - Maple_root -CISCN2021 总结 总得分:3400 总排名:203 赛区排名:21 第一次认真参加正式的CTF,24+3小时的脑血栓比赛时长,收获还是很多的. 开卷 ...
- rocketmq-spring : 实战与源码解析一网打尽
RocketMQ 是大家耳熟能详的消息队列,开源项目 rocketmq-spring 可以帮助开发者在 Spring Boot 项目中快速整合 RocketMQ. 这篇文章会介绍 Spring Boo ...