python如何实现元素等待

一、为什么要元素等待?

  在UI自动化过程中,元素的出现受网络环境、设备性能等多种元素影响。因此,元素加载和脚本运行到该元素的时间不一致,会报错:元素无法定位。

  简单举下例子:实际UI自动化测试中,点击一个登录控件需要启动一个新activity界面,或需要加载弹框,或请求网络加载数据成功后刷新页面,此时需要等待一段时间,新界面出现了才能继续执行UI操作,否则数据还在加载ing,脚本已开始执行新界面操作的代码,脚本就会报错。

二、元素等待的作用

  1. 设置元素等待,增强脚本的健壮性,提高执行效率;
  2. 本质是为了解决时序不匹配:脚本执行时,脚本的执行速度和页面元素的加载速度未必一致

三、元素等待类型

  1. 强制等待:死等待,设置固定的等待时间                      -- sleep(2)   # 强制等待5s,要导入时间包(import time)
  2. 隐性等待:针对全度元素设置的等待时间       -- driver.implicitly_wait(5)
  3. 显性等待:针对某个元素来设置的等待时间   -- WebDriverWait(driver,timeout,poll_frequency=0.5,ignored_exception=None),要导入包(from selenium.webdriver.support.ui import WebDriverWait)

四、怎么设置元素等待

  1.强制等待的应用实例:

from appium import webdriver
import time
desired_caps = {}
desired_caps[‘platformName‘] = ‘Android‘
desired_caps[‘platformVersion‘] = ‘5.1.1‘
desired_caps[‘deviceName‘] = ‘127.0.0.1:62001‘
desired_caps[‘packageName‘] = ‘com.cnblogs.android‘
desired_caps[‘packagActivity‘] = ‘com.cnblogs.android.SplashActivity‘
desired_caps[‘unicodeKeyboard‘] = True
desired_caps[‘resetKeyboard‘] = True
driver = webdriver.Remote(‘http://127.0.0.1:8888/wd/hub‘,desired_caps)
# 强制等待5s,不管等待的元素是否出现,都要等5s
time.sleep(5)
driver.find_element_by_id(‘com.cnblogs.android:id/TabSearch‘).click()
time.sleep(2)
driver.find_element_by_id(‘com.cnblogs.android:id/txtSearch‘).send_keys(‘方缘‘)
driver.find_element_by_id(‘com.cnblogs.android:id/search_btn‘).click()
driver.quit()

  2.隐性等待:

from appium import webdriver
import time
desired_caps = {}
desired_caps[‘platformName‘] = ‘Android‘
desired_caps[‘platformVersion‘] = ‘5.1.1‘
desired_caps[‘deviceName‘] = ‘127.0.0.1:62001‘
desired_caps[‘packageName‘] = ‘com.cnblogs.android‘
desired_caps[‘packagActivity‘] = ‘com.cnblogs.android.SplashActivity‘
desired_caps[‘unicodeKeyboard‘] = True
desired_caps[‘resetKeyboard‘] = True
driver = webdriver.Remote(‘http://127.0.0.1:8888/wd/hub‘,desired_caps)
# 隐性等待(等待所有元素),最长3s
driver.implicitly_wait(3)
driver.find_element_by_id(‘com.cnblogs.android:id/TabSearch‘).click()
time.sleep(2)
driver.find_element_by_id(‘com.cnblogs.android:id/txtSearch‘).send_keys(‘方缘‘)
driver.find_element_by_id(‘com.cnblogs.android:id/search_btn‘).click()
driver.quit()

  3.显性等待:

from appium import webdriver
from selenium.webdriver.support.ui import WebDriverWait
import time
desired_caps = {}
desired_caps[‘platformName‘] = ‘Android‘
desired_caps[‘platformVersion‘] = ‘5.1.1‘
desired_caps[‘deviceName‘] = ‘127.0.0.1:62001‘
desired_caps[‘packageName‘] = ‘com.cnblogs.android‘
desired_caps[‘packagActivity‘] = ‘com.cnblogs.android.SplashActivity‘
desired_caps[‘unicodeKeyboard‘] = True
desired_caps[‘resetKeyboard‘] = True
driver = webdriver.Remote(‘http://127.0.0.1:8888/wd/hub‘,desired_caps)
# 显性等待(等待特定元素出现)
# lambda 提供了一个运行时动态创建函数的方法。
WebDriverWait(driver,3).until(lambda x: x.find_element_by_id(‘com.cnblogs.android:id/TabSearch‘)).click()
driver.find_element_by_id(‘com.cnblogs.android:id/TabSearch‘).click()
time.sleep(2)
driver.find_element_by_id(‘com.cnblogs.android:id/txtSearch‘).send_keys(‘方缘‘)
driver.find_element_by_id(‘com.cnblogs.android:id/search_btn‘).click()
driver.quit()

原文地址:https://www.cnblogs.com/huainanhai/p/11831277.html

时间: 2024-10-16 21:21:02

python如何实现元素等待的相关文章

Selenium with Python 008 - WebDriver 元素等待

如今大多数Web应用程序使用Ajax技术,当浏览器在加载页面时,页面上的元素可能并不是同时被加载完成的,这给元素的定位增加了困难.如果因为在加载某个元素时延迟而造成ElementNotVisibleException的情况出现,那么就会降低自动化脚本的稳定性,我们可以通过设置元素等待改善这种问题造成的不稳定. WebDriver提供了两种类型的等待:含蓄等待和明确等待.明确等待作用于特定代码块,使得WebDriver等待某个条件成立时继续执行,否则在达到最大时长时抛出超时异常:而含蓄等待,属于全

Python+Selenium笔记(十):元素等待机制

 (一) 前言 突然的资源受限或网络延迟,可能导致找不到目标元素,这时测试报告会显示测试失败.这时需要一种延时机制,来使脚本的运行速度与程序的响应速度相匹配,WebDriver为这种情况提供了隐式等待和显式等待两种机制. (二) 隐式等待 一旦设置隐式等待时间,就会作用于这个WebDriver实例的整个生命周期(对所有的元素查找都生效),设置隐式等待时间后,Webdriver会在一定时间内持续检测和搜寻DOM,以便于查找一个或多个不是立即加载成功并可用的元素.隐式等待的默认时间是0. WebDr

python selenium系列(四)元素等待

一 前言 在前面的selenium系列(二)元素定位方式和selenium系列(三)常用操作类型及方法两节中,已经介绍了web页面元素的识别定位.操作等技术,可能你会觉得掌握这两项技术就可以实施web自动化了,答案基本是这样的,毕竟元素定位和操作是核心技术.但是,在某些场景,脚本的运行并非预期那样,如,要操作的元素用常规方法无法识别.元素可以识别但在脚本运行时却未如期而至等.为了解决这些疑难杂症,接下来三节内容将会介绍处理这些问题的通用方法. 在本节,主要介绍元素等待的使用方法和场景,该方法是开

元素等待

为什么要设置元素等待?当你的网络慢的时候,打开网页慢,网页都没完全打开,代码已经在执行了,但是没找到你定位的元素,此时python会报错.当你的浏览器或电脑反应慢,网页没完全打开,代码已经在执行了,但是没找到你定位的元素,此时python也会报错.由于代码执行很快,而由于各方面的原因导致python代码报错,所以才要设置元素等待.是根据你的网速或电脑的情况而定来设置等待时间,没有一成不变的设置,这个需要注意. 1.time.sleep() 强制等待 优点:代码简洁,不啰嗦.缺点:假如你设置sle

WebDriver API——延时操作及元素等待

在自动化测试过程当中,受网络.测试设备等诸多因素的影响,我们经常需要在自动化测试脚本中添加一些延时来更好的定位元素来进行一系列的操作. 一般有这么几种方式: 1.implicitlyWait.识别对象时的超时时间.过了这个时间如果对象还没找到的话就会抛出NoSuchElement异常 2.setScriptTimeout.异步脚本的超时时间.webdriver 可以异步执行脚本,这个是设置异步执行脚本脚本返回结果的超时时间. 3.pageLoadTimeout.页面加载时的超时时间.因为webd

Selenium2+python自动化,判定元素是否存在

Selenium2+python自动化,判定元素是否存在 前言 最近有很多小伙伴在问如何判断一个元素是否存在,这个方法在selenium里面是没有的,需要自己写咯. 元素不存在的话,操作元素会报错,或者元素有多个,不唯一的时候也会报错.本篇介绍两种判断元素存在的方法. 一.find_elements方法判断 1.find_elements方法是查找页面上所有相同属性的方法,这个方法其实非常好用,能熟练掌握技巧的不多,小编这次就发挥它的功效 2.由于元素定位的方法很多,所以判断的时候定位方法不统一

Web自动化测试 四 ----- python selenium 八大元素定位

python selenium 八大元素定位方法 前提条件:先要引入webdriver模块,创建一个Chrom浏览器对象,以及打开一个网页(以百度为例). 1 from selenium import webdriver 2 3 driver = webdriver.Chrome() 4 5 driver.get('http://www.baidu.com') 一.ID定位 driver.find_element_by_id('kw') 备注: 此方法相当于JS中的getElementById(

5 元素等待

元素等待 1 显示等待(了解) 概念:使WebDriver等待指定元素条件成立时继续执行,否则在达到最大时长时抛出超时异常(TimeoutException) 在WebDriver中把显式等待的相关方法封装在WebDriverWait类中 等待是判定条件成立时,那如何判断条件成立?相关判断的方法封装在expected_conditions类中 实现难点分析 1. 导包 等待类 from selenium.webdriver.support.wait import WebDriverWait 2.

python里三种等待元素的方法

在做web或app的自动化测试经过会出现找不到元素而报错的情况,很多时候是因为元素 还没有被加载出来,查找的代码就已经被执行了,自然就找不到元素了.那么我可以用等待 元素加载完成后再执行查找元素的code. Python里有三种等待的方式:一. 强制等待 Sleep(54) 这个方法在time模块,使用时通过from time import sleep导入比如: Sleep(10) #表示强行等待10s再执行下一句代码 Driver.find_element_by_xpath("xxxxxx&q