Selenium - 元素等待

显式等待

  • 显式等待是一种灵活的等待方式,需要声明等待的结束条件,当满足条件时会自动结束等待;

    • 需要引入WebDriverWait包以及exception_conditionswait方法配合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等待场景

转载:https://blog.csdn.net/kelanmomo/article/details/82886718

介绍

  • 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)
  • 注:presencevisibility有点相像,区别在于:

    • presence 强调元素存在于DOM树中,可见不可见无所谓;(性能上会稍微快一点点)

    • visibility要求必须高和宽必须都大于0;

Selenium - 元素等待(2) - 显式等待/EC等待的更多相关文章

  1. selenium—隐式等待和显式等待

    一.隐式等待和显式等待的区别 隐式等待:是整个页面的等待.设置一个最长的等待时间,在规定时间内整个页面加载完成,则执行下一步,否则继续等待直到最长等待时间结束. 显式等待:是针对某个元素的等待.在设置 ...

  2. Selenium系列(六) - 强制等待、隐式等待、显式等待

    如果你还想从头学起Selenium,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1680176.html 其次,如果你不懂前端基础知识, ...

  3. selenium(5)-解读强制等待,隐式等待,显式等待的区别

    背景 为什么要设置元素等待 因为,目前大多数Web应用程序都是使用Ajax和Javascript开发的:每次加载一个网页,就会加载各种HTML标签.JS文件 但是,加载肯定有加载顺序,大型网站很难说一 ...

  4. Selenium4+Python3系列(六) - Selenium的三种等待,强制等待、隐式等待、显式等待

    为什么要设置元素等待 直白点说,怕报错,哈哈哈! 肯定有人会说,这也有点太直白了吧. 用一句通俗易懂的话就是:等待元素已被加载完全之后,再去定位该元素,就不会出现定位失败的报错了. 如何避免元素未加载 ...

  5. selenium的webdriver三种等待方式(显式等待WebDriverWait+implicitly_wait隐式等待+sleep强制等待)

    隐式等待是等页面加载,不是等元素!!! 1.显式等待 一个显式等待是你定义的一段代码,用于等待某个条件发生然后再继续执行后续代码.显式等待是等元素加载!!! 2.隐式等待,相当于设置全局的等待,在定位 ...

  6. “全栈2019”Java多线程第三十二章:显式锁Lock等待唤醒机制详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

  7. selenium 隐式等待与显式等待

    1.隐式等待:driver.implicitly_wait() driver = webdriver.Chrome()driver.implicitly_wait(10)     #获取元素时最多会等 ...

  8. Selenium+Java(六)Selenium 强制等待、显式等待、隐实等待

    前言 在实际测试过程中,由于网速或性能方面的原因,打开相应的网页后或在网页上做了相应的操作,网页上的元素可能不会马上加载出来,这个时候需要在定位元素前等待一下,等元素加载出来后再进行定位,根据实际使用 ...

  9. 【亲测显式等待】Selenium:元素等待的4种方法

    Selenium:元素等待的4种方法 1.使用Thread.sleep(),这是最笨的方法,但有时候也能用到而且很实用.   2.隐式等待,隐性等待是指当要查找元素,而这个元素没有马上出现时,告诉We ...

  10. 显式等待-----Selenium快速入门(十)

    上一篇说了元素定位过程中的隐式等待,今天我们来探讨一下显示等待.显式等待,其实就是在使用WebDriverWait这个对象,进行等待.显式等待对比隐式等待,多了一些人性化的设置,可以说是更细化的隐式等 ...

随机推荐

  1. (转)解决ubuntu下拼音输入法出错的问题

    一.如果仅在中文输入法下出现按键映射错位而英文输入下正常的情况,则在终端下输入以下命令即可: ibus-daemon -drx 二.如果拼音正常但打出来显示 "[Invalid UTF-8] ...

  2. 驱动开发:配置Visual Studio驱动开发环境

    在正式开始驱动开发之前,需要自行搭建驱动开发的必要环境,首先我们需要安装Visual Studio 2013这款功能强大的程序开发工具,在课件内请双击ISO文件并运行内部的vs_ultimate.ex ...

  3. AI 影评家:用 Hugging Face 模型打造一个电影评分机器人

    本文为社区成员 Jun Chen 为 百姓 AI 和 Hugging Face 联合举办的黑客松所撰写的教程文档,欢迎你阅读今天的第二条推送了解和参加本次黑客松活动.文内含有较多链接,我们不再一一贴出 ...

  4. Cesium 后处理(Post Process)

    原文地址:https://blog.csdn.net/ls870061011/article/details/123910821 作者:GIS李胜 为实现三维模型的更炫.更酷.更美观,Cesium在1 ...

  5. java面向对象-类与对象,构造器

    java面向对象-类与对象,构造器 类与对象 package charpter5.Demo; public class Student { //属性:字段 static String name2=&q ...

  6. 在Pycharm上使用远程服务器进行调试

    前言 缘起   Mac上没有GPU,需要用到学校服务器进行调试,于是产生了这篇博客.0.0bb 前提    首先确保已经将Pycharm配置好,通过SSH连接到服务器上的开发环境,这一步网络上有许多教 ...

  7. 系统论——复杂适应系统CAS(三)

    美国的圣塔菲研究所一直是复杂性研究的中心.1994年,约翰·霍兰德在圣菲研究所举办的吴拉姆纪念讲座中做了名为"隐秩序"的著名演进,而后,出版了<隐秩序-适应性造就复杂性> ...

  8. modbus_new_rtu

    /** * modbus_new_rtu(const char *device, int baud, char parity, int data_bit, int stop_bit); * 这个函数会 ...

  9. Java设计模式 —— 组合模式

    11 组合模式 11.1 组合模式概述 Composite Pattern: 组合多个对象形成树形结构以表示具有部分-整体关系的层次结构.组合模式使得客户端可以统一处理单个对象和组合对象. 组合模式关 ...

  10. stm32串口烧录程序

    Step1:将BOOT0设置为1,BOOT1设置为0,mcuisp软件不使用STR和DTR烧录 Step2:程序下载完成后,再将BOOT0手动跳帽接GND,复位,这样STM32才可以从Flash中启动 ...