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. 自动化兼容性测试工具——WeTest

    这个作业属于哪个课程 2021春软件工程实践|W班(福州大学) 这个作业要求在哪里 软件工程实践总结&个人技术博客 这个作业的目标 分享自动化兼容性测试工具的使用 其他参考文献 ... 目录 ...

  2. (2)请用requests库的get()函数访问如下一个网站20次,打印返回状态,text()内容,计算text()属性和content属性所返回网页内容的长度。

    # 导入库 import requests from bs4 import BeautifulSoup def getUrlText(url): try: web = requests.get(url ...

  3. Python基础教程:赋值的多个方式

    一.序列解包/可迭代对象解包 释义:将一个序列(或任何可迭代的对象)解包,并将得到的值存储到一系列变量中. 1.并行赋值 >>> x,y,z = 1,2,3 >>> ...

  4. 痞子衡嵌入式:我为2021 TencentOS Tiny AIoT应用创新大赛做了场直播培训

    TencentOS Tiny AIoT 应用创新大赛是腾讯 TencentOS 团队联合恩智浦半导体.安谋科技(Arm China)发起的线上开发者活动,主要面向中小企业嵌入式工程师.广大嵌入式开发者 ...

  5. Bootstarp5第四弹

    六.颜色 <div class="container mt-3">最基本的文本 <p class="text-muted">柔和的文本& ...

  6. Android笔记--文本输入

    编辑框EditText 相关内部部件取下: inputType的类型如下: 具体实现: 不同边框的实现: 焦点变更监听器 具体实现: 文本变化监听器 具体实现:

  7. Javaweb知识复习--MyBatis+Mapper代理开发

    一种持久层框架,主要用于简化JDBC MyBatis应用步骤 1.在数据库里面创建一个表 2.创建模块,导入坐标 就是新建一个Maven项目,在pom.xml里面导入mybatis相应导包依赖代码: ...

  8. Promise的使用及原理

    此文章主要讲解核心思想和基本用法,想要了解更多细节全面的使用方式,请阅读官方API 这篇文章假定你具备最基本的异步编程知识,例如知道什么是回调,知道什么是链式调用,同时具备最基本的单词量,例如page ...

  9. iOS 深色模式适配

    要求:iOS13.0以上 重点:需要所有界面进行适配,工作量巨大,需要从项目开始就进行适配:H5界面无法进行适配 实现方式:System Colors(常用).Semantic Colors(常用). ...

  10. What's the best way to read and understand someone else's code?

    Find one thing you know the code does, and trace those actions backward, starting at the end Say, fo ...