Selenium三大等待详解

🍅 视频学习:文末有免费的配套视频可观看

🍅 关注公众号【互联网杂货铺】,回复 1 ,免费获取软件测试全套资料,资料在手,涨薪更快

一、强制等待

1.设置完等待后不管有没有找到元素,都会执行等待,等待结束后才会执行下一步

2.实例:

driver = webdriver.Chrome()driver.get("https://www.baidu.com")time.sleep(3)  # 设置强制等待driver.quit()

二、隐性等待

1.设置全局等待,对每个查询的元素都生效,当页面元素没有第一时间找到,会等待implicitly_wait设置的时间,时间过后再查找一次,要是还没找到就报错。

2.实例:

driver = webdriver.Chrome()driver.get("https://www.baidu.com")driver.implicitly_wait(10)  # 设置隐性等待driver.quit() 

三、显性等待

1.WebDriverWait类

1)导入webdriverwait类

from selenium.webdriver.support.wait import WebDriverWait

2)实例化WebDriverWait

wait = WebDriverWait(driver, 10, 2)  # 10为等待时间,2为在10s内每过2s去判断一次

selenium提供了WebdriverWait类用于针对指定的元素设置等待,其中内含until和until_not两个方法判断。

3)until(self, method, message: str = "")  函数

methon:为判断条件,若返回true,则判断成功,返回false,判断失败,打印message信息。

message:为判断失败时打印的信息,可写可不写。

 driver = webdriver.Chrome()driver.get("https://www.baidu.com")wait = WebDriverWait(driver, 10, 2)  # 设置显性等待wait.until("判断条件", "返回false时打印的信息")driver.quit()

4)until_not(self, method, message: str = "") 函数

until_not效果与until相反,返回false时判断成功,返回true时判断失败。

driver = webdriver.Chrome()driver.get("https://www.baidu.com")wait = WebDriverWait(driver, 10, 2)  # 设置显性等待wait.until_not("判断条件", "返回true时打印的信息")driver.quit()

5)判断条件通常与expected_conditions连用,内部封装了判断方法。expected_conditions的具体用法,我们接着往下看。

2.expected_conditions

下面介绍expected_conditions模块下所有的函数用法

1)title_is:精准匹配页面标题,匹配成功返回true,失败返回false

from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium.webdriver.support.expected_conditions import *option = webdriver.ChromeOptions()option.add_argument("--headless")  # 设置无窗口模式driver = webdriver.Chrome(options=option) <br>driver.get("https://www.baidu.com") <br>wait = WebDriverWait(driver, 10, 2) # 设置显性等待 <br>wait.until(title_is("百度一下,你就知道")) # 精准匹配标题 <br>driver.quit()

2)title_contains:模糊匹配标题,匹配成功返回true,失败返回false

from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium.webdriver.support.expected_conditions import *option = webdriver.ChromeOptions()option.add_argument("--headless")  # 设置无窗口模式driver = webdriver.Chrome(options=option)driver.get("https://www.baidu.com")wait = WebDriverWait(driver, 10, 2)  # 设置显性等待wait.until(title_contains("百度"))  # 模糊匹配标题driver.quit()

3)presence_of_element_located:判断定位的元素是否存在(可见和隐藏元素),存在返回true,否则返回false。

from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium.webdriver.support.expected_conditions import *option = webdriver.ChromeOptions()option.add_argument("--headless")  # 设置无窗口模式driver = webdriver.Chrome(options=option)driver.get("https://www.baidu.com")wait = WebDriverWait(driver, 10, 2)  # 设置显性等待wait.until(presence_of_element_located((By.ID, "kw")), "不存在")  # 判断元素是否存在,可见和隐藏元素都可判断driver.quit()

4)url_contains:判断页面url地址是否包含预期结果,满足预期返回true,不满足返回false。

from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium.webdriver.support.expected_conditions import *option = webdriver.ChromeOptions()option.add_argument("--headless")  # 设置无窗口模式driver = webdriver.Chrome(options=option)driver.get("https://www.baidu.com")wait = WebDriverWait(driver, 10, 2)  # 设置显性等待wait.until(url_contains("baidu1"), "不包含")  # 检测当前页面url地址是否包含预期结果driver.quit()

5)url_matches:判断当前页面地址是否包含预期结果,内填写正则表达式,满足预期返回true,不满足返回false。

from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium.webdriver.support.expected_conditions import *option = webdriver.ChromeOptions()option.add_argument("--headless")  # 设置无窗口模式driver = webdriver.Chrome(options=option)driver.get("https://www.baidu.com")wait = WebDriverWait(driver, 10, 2)  # 设置显性等待wait.until(url_matches("baidu"), "不包含")  # 检测当前页面url地址是否包含预期结果,内填写正则表达式driver.quit()

6)url_to_be:精准判断url,若相同返回true,不同返回false

from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium.webdriver.support.expected_conditions import *option = webdriver.ChromeOptions()option.add_argument("--headless")  # 设置无窗口模式driver = webdriver.Chrome(options=option)driver.get("https://www.baidu.com")wait = WebDriverWait(driver, 10, 2)  # 设置显性等待wait.until(url_to_be("https://www.baidu.com/"), "不存在")  # 精准判断urldriver.quit()

7)url_changes:精准判断url,若相同返回false,不同返回true。

from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium.webdriver.support.expected_conditions import *option = webdriver.ChromeOptions()option.add_argument("--headless")  # 设置无窗口模式driver = webdriver.Chrome(options=option)driver.get("https://www.baidu.com")wait = WebDriverWait(driver, 10, 2)  # 设置显性等待wait.until(url_changes("https://www.baidu.c"), "相等")  # 精准匹配url不相等driver.quit()

8)visibility_of_element_located:判断定位的元素是否存在,只能判断可见元素,存在返回true,不存在返回false。

from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium.webdriver.support.expected_conditions import *option = webdriver.ChromeOptions()option.add_argument("--headless")  # 设置无窗口模式driver = webdriver.Chrome(options=option)driver.get("https://www.baidu.com")wait = WebDriverWait(driver, 10, 2)  # 设置显性等待wait.until(visibility_of_element_located((By.ID, "kw")), "不存在")  # 判断元素是否存在,只适用于可见元素driver.quit()

9)visibility_of:判断元素是否存在,只能判断可见元素

from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium.webdriver.support.expected_conditions import *option = webdriver.ChromeOptions()option.add_argument("--headless")  # 设置无窗口模式driver = webdriver.Chrome(options=option)driver.get("https://www.baidu.com")wait = WebDriverWait(driver, 10, 2)  # 设置显性等待element_id = driver.find_element(by=By.ID, value="kw")wait.until(visibility_of(element_id), "不存在")  # 判断元素是否存在,只适用于可见元素driver.quit()

此方法与visibility_of_element_located判断结果相同,只是传递参数不同,visibility_of传元素,visibility_of_element_located传元组

10)presence_of_all_elements_located:判断页面至少有一个定位的元素存在(可见和隐藏元素都会判断)。

wait.until(presence_of_all_elements_located((By.TAG_NAME, "span")), "没有一个存在")  # 判断页面至少有一个定位的元素存在(可见和隐藏元素都会判断)

11)visibility_of_any_elements_located:判断页面至少有一个定位的元素存在,且为可见元素。

wait.until(visibility_of_any_elements_located((By.TAG_NAME, "span")), "没有一个存在")  # 判断页面至少有一个定位的元素存在,且为可见元素

12)visibility_of_all_elements_located:判断定位的元素全部可见。

wait.until(visibility_of_all_elements_located((By.TAG_NAME, "span")), "不可见")  # 判断定位的元素全部可见

13)text_to_be_present_in_element:模糊匹配文本值。

wait.until(text_to_be_present_in_element((By.XPATH, "//span[contains(text(),'123')]"), "124"), "匹配不成功")  # 模糊匹配元素文本值

14)text_to_be_present_in_element_value:模糊匹配定位元素的value值。

 wait.until(text_to_be_present_in_element_value((By.XPATH, "//input[@id='su']"), "百度一下"), "匹配错误")  # 模糊匹配元素value值

15)text_to_be_present_in_element_attribute:模糊匹配定位元素指定属性的属性值。

wait.until(text_to_be_present_in_element_attribute((By.XPATH, "//input[@id='kw']"), "name", "w"), "匹配错误")  # 模糊匹配定位元素指定属性的属性值

16)frame_to_be_available_and_switch_to_it:判断frame是否可以切换(switch_to.frame())。

wait.until(frame_to_be_available_and_switch_to_it((By.XPATH, "elenment")), "不可切换")  # 判断frame是否可以切换

17)invisibility_of_element_located:判断定位的元素是否不可见或者不存在,不可见返回true,反之返回false

wait.until(invisibility_of_element_located((By.TAG_NAME, "span")), "错误")  # 判断元素是否不可见/不存在,不可见返回true

18)invisibility_of_element:判断元素是否不可见或者不存在,不可见返回true,反之返回false。

span=driver.find_element(By.TAG_NAME, "span")wait.until(invisibility_of_element(span), "错误")  # 判断元素是否不可见或者不存在,不可见返回true,反之返回false

与invisibility_of_element_located用法相同,只是传递参数不同,一个传元素,一个传元组。

19)element_to_be_clickable:判断定位的元素是否可点击

 wait.until(element_to_be_clickable((By.ID, "su")), "错误")  # 判断定位的元素是否可点击

20)staleness_of:判断元素是否存在,存在若在等待的时间内被移除,则返回true

span = driver.find_element(By.ID, "su")
wait.until(staleness_of(span), "错误")  # 判断元素是否存在,存在若在等待的时间内被移除,则返回true

这里注意的是传递的参数是元素。

21)element_to_be_selected:判断元素是否被选中

id=driver.find_element(by=By.XPATH, value="//option[contains(text(),'2')]")
wait.until(element_to_be_selected(id),"失败")  # 判断可见元素是否选中

这里注意的是传递的参数是元素。

22)element_located_to_be_selected:判断定位的元素是否被选中,选中返回true,未选中返回false。

wait.until(element_located_to_be_selected((By.XPATH, "//option[contains(text(),'1')]")),"失败")  # 判断定位的元素是否被选中

与element_to_be_selected用法相同,不同的是传递的是元组。

23)element_selection_state_to_be:判断元素选中的状态是否符合预期

id=driver.find_element(by=By.XPATH, value="//option[contains(text(),'2')]")<br><br>wait.until(element_selection_state_to_be(id,False),"选中了")  # 判断元素是否被选中,并给出预期结果

与element_selection_state_to_be用法相同,不同的是传递的元组。

25)number_of_windows_to_be:判断当前打开的窗口是否符合预期。

wait.until(number_of_windows_to_be(1),"不是一个")  # 期望当前打开的窗口数为几个

26)new_window_is_opened:判断是否新打开了一个窗口。

hand = driver.window_handles  # 获取当前所有窗口的柄句print(len(hand))driver.find_element(by=By.XPATH, value="//a[contains(text(),'新闻')]").click()wait.until(new_window_is_opened(hand))  # 判断是否打开了一个新窗口

27)alert_is_present:判断页面是否有alert。

wait.until(alert_is_present(),"没有alert")  # 判断页面是否有alert

28)element_attribute_to_include:判断定位的元素是否存在预期的属性值。

这个我们就不做多余的介绍了,因为本身封装的就有问题,我们先来看下封装的原代码:

通过get_attribute(attribute_)获取属性值,若为none则返回false,否则返回不为none,其实这点是存在问题的

因为get_attribute(attribute_)当属性不存在时是什么都不会返回的,更不会返回none。

29)any_of:判断多个条件满足一个为true的话就返回true,相当于or逻辑

wait.until(any_of(alert_is_present(), element_attribute_to_include((By.TAG_NAME, "a"), "name")), "没有一个符合要求的")  # 多个判断条件有一个返回true,则返回True,or逻辑

30)all_of:判断多个条件必须都满足为true的话才返回true,相当于and逻辑

wait.until(all_of(alert_is_present(), element_attribute_to_include((By.TAG_NAME, "a"), "name")))  # 多个判断条件必须都满足,True,and逻辑

31)none_of:判断多个条件都返回false时,才能判断成功返回true

wait.until(none_of(alert_is_present(), element_attribute_to_include((By.TAG_NAME, "a"), "name")))  # 判断多个条件都返回flase时返回true,有一个返回true时则返回false

同时,在这我为大家准备了一份软件测试视频教程(含面试、接口、自动化、性能测试等),就在下方,需要的可以直接去观看,也可以直接【点击文末小卡片免费领取资料文档】

花了2万多买的自动化测试全套教程,现在分享给大家,入门到精通,全程干货无废话(软件测试全栈教程))

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/572286.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

目前可用的免费云服务器整理汇总

随着云计算技术的飞速发展&#xff0c;越来越多的企业和个人开始关注并使用云服务器。为了吸引用户上云&#xff0c;各大云服务商纷纷推出了免费云服务器&#xff0c;供用户免费试用。本文将为大家整理汇总目前市场上可用的免费云服务器&#xff0c;以便大家更好地选择适合自己…

Cisco防火墙

ASA系列 1、防火墙工作原理&#xff08;状态化防火墙&#xff09; 2、在防火墙上配置ACL&#xff08;基本都是命名的ACL&#xff09; 3、在防火墙上配置NAT&#xff08;防火墙设备一般放在局域网出口&#xff09; 一、工作原理 1、系列 ASA550系列 2、ASA防火墙状态化防…

Kubernetes超详细教程,一篇文章帮助你从零开始学习k8s,从入门到实战

k8s 概述 k8s github地址&#xff1a;https://github.com/kubernetes/kubernetes 官方文档&#xff1a;https://kubernetes.io/zh-cn/docs/home/ k8s&#xff0c;全程是 kubernetes&#xff0c;这个名字源于希腊语&#xff0c;意为"舵手"或"飞行员” k8s 这…

C#学生信息成绩管理系统

一、系统功能描述 本系统包括两类用户&#xff1a;学生、管理员。管理员可以通过系统来添加管理员信息、修改管理员信息、添加学生信息、修改学生信息&#xff1b;开设课程、查询课程、录入成绩、统计成绩、修改成绩、修改个人密码等&#xff0c;而学生则可以通过系统来选择课…

Matlab基础入门

基础操作&#xff1a; matlab命令行操作&#xff1a; matlab可以使用命令行执行程序&#xff0c;例如下图运行后在右边工作区会产生响应的变量&#xff0c;如不写分号&#xff0c;则会直接运行。 clear命令&#xff1a;clear用于清除变量。clc命令&#xff1a;clc用于清屏。 m…

VMware和Xshell连接

1.开启虚拟机 2.使用管理员账户&#xff0c;点击未列出 3.输入用户名密码 4.点击编辑虚拟网络编辑器 5.记住自己的网关和IP地址 6.打开终端 7.输入命令&#xff0c;vim / etc / sysconfig / network -scripts / ifcfg-ens33 回车 8.修改图中两处按“ I ”键进入编辑 d…

3-iperf3 使用什么工具可以检测网络带宽、延迟和数据包丢失率等网络性能参数呢?

(1)iperf3简介 1.iperf3简介 2.用途&#xff08;特点&#xff09; 3.下载iperf3地址 &#xff08;2&#xff09;实战 1.iperf3参数 &#xff08;1&#xff09;通用参数&#xff08;客户端和服务器端都是适用的&#xff09; &#xff08;2&#xff09;客户端参数 实验1&…

对下载软件/文件进行校验的工具(Checksum and GPG)

前言 之前装软件一直都没有验证安装文件的习惯&#xff0c;信息安全意识不高&#xff0c;碰巧最近没啥事&#xff0c;微微写篇文章记录下校验工具&#xff08;互联网http、https、ftp 服务并没有那么安全&#xff0c;是可以被劫持篡改。老装软件选手了&#xff0c;是该养成个校…

MySQL连接与存储

目录 一.连接查询 1.内连接 2.左连接 3.右连接 二.存储过程 1.定义 2.优点 &#xff08;1&#xff09;执行一次后&#xff0c;会将生成的二进制代码驻留缓冲区&#xff0c;提高执行效率 &#xff08;2&#xff09;SQL语句加上控制语句的集合&#xff0c;灵活性高 &am…

Unity3d C#转换微信小游戏 Dotween插件在苹果(IOS)设备中异常问题高性能模式修复

问题 使用minigame-unity-webgl-transform插件转换微信小游戏&#xff0c;功能在安卓和开发工具上都能正常&#xff0c;不过使用Dotween(版本DOTweenPro v1.0.244)插件实现的功能在苹果系统中却都不能正常对比如下&#xff1a; 云移动正常&#xff1a; 云移动IOS异常&#x…

图形界面开发-framebuffer技术

https://www.linuxidc.com/Linux/2012-05/61024.htm 1、framebuffer 帧缓冲 帧缓冲&#xff08;framebuffer&#xff09;是Linux 系统为显示设备提供的一个接口&#xff0c;它将显示缓冲区抽象&#xff0c;屏蔽图像硬件的底层差异&#xff0c;允许上层应用程序在图形模式下直接…

Android 性能优化实例分享-内存优化 兼顾效率与性能

背景 项目上线一段时间后,回顾重要页面 保证更好用户体验及生产效率&#xff0c;做了内存优化和下载导出优化&#xff0c;具体效果如最后的一节的表格所示。 下面针对拍摄流程的两个页面 预览页 导出页优化实例进行介绍&#xff1a; 一.拍摄前预览页面优化 预览效果问题 存在…