一、為什么要使用等待?
在自動化測試腳本的運行過程中,webdriver操作瀏覽器的時候,對于元素的定位是有一定的超時
時間,大致在1-3秒
如果這個時間內(nèi)仍然定位不到元素,就會拋出異常,中止腳本執(zhí)行
我們可以通過在腳本中設(shè)置等待的方式來避免由于網(wǎng)絡(luò)延遲或瀏覽器卡頓導致的偶然失敗
二、常用的三種等待方式
- 強制等待
- 隱式等待
- 顯示等待
三、強制等待
利用time模塊的sleep方法來實現(xiàn),最簡單粗暴的等待方法
強制等待,不管你瀏覽器是否加載完成,都得給我等待3秒,3秒一到,繼續(xù)執(zhí)行下面的代碼
1
2
3
4
5
6
7
8
9
10
11
12
|
# -*- coding: utf-8 -*- # @Author : 程序員一凡 import time from selenium import webdriver driver = webdriver.Chrome() # 打開百度首頁 driver.get(r 'https://www.baidu.com/' ) # 強制等待3秒 time.sleep( 3 ) driver.find_element_by_css_selector( "#kw" ).send_keys( "selenium" ) # 退出 driver.quit() |
弊端
不建議用這種等待方法,嚴重影響代碼的執(zhí)行速度
四、隱式等待
implicitly_wait()方法用來等待頁面加載完成(直觀的就是瀏覽器tab頁上的小圈圈轉(zhuǎn)完)網(wǎng)頁加載
完成則執(zhí)行下一步
隱式等待只需要聲明一次,一般在打開瀏覽器后進行聲明
聲明之后對整個drvier的生命周期都有效,后面不用重復聲明
1
2
3
4
5
6
7
8
9
10
11
12
|
# -*- coding: utf-8 -*- # @Author : 程序員一凡 import time from selenium import webdriver driver = webdriver.Chrome() # 打開百度首頁 driver.get(r 'https://www.baidu.com/' ) # 隱性等待5秒 driver.implicitly_wait( 5 ) driver.find_element_by_css_selector( "#kw" ).send_keys( "selenium" ) # 退出 driver.quit() |
弊端
程序會一直等待整個頁面加載完成,直到超時
有時候我需要的那個元素早就加載完成了,只是頁面上有個別其他元素加載特別慢,我仍要等待頁
面全部加載完成才能執(zhí)行下一步
五、顯示等待
WebDriverWait,配合該類的until()和until_not()方法,就能夠根據(jù)判斷條件而進行靈活地等待了
它主要的意思就是:程序每隔xx秒看一眼,如果條件成立了,則執(zhí)行下一步
否則繼續(xù)等待,直到超過設(shè)置的最長時間,然后拋出TimeoutException
顯示等待必須在每個需要等待的元素前面進行聲明
1
2
|
# 導入模塊 from selenium.webdriver.support.wait import WebDriverWait |
四個參數(shù)
driver:瀏覽器驅(qū)動
timeout:等待時間
poll_frequency:檢測的間隔時間,默認0.5s
ignored_exceptions:超時后的異常信息,默認拋出NoSuchElementException
expected_conditions
expected_conditions是selenium的一個模塊
包含一系列可用于判斷的條件
可以對網(wǎng)頁上元素是否存在,可點擊等等進行判斷,一般用于斷言或與WebDriverWait配合使用
1
|
from selenium.webdriver.support import expected_conditions as EC |
1
2
3
4
5
6
7
8
9
10
11
12
|
# -*- coding: utf-8 -*- # @Author : 程序員一凡 from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.support.wait import WebDriverWait from selenium.webdriver.support import expected_conditions as EC driver = webdriver.Chrome() driver.get( 'https://www.baidu.com' ) # 等待10s,等待過程中如果定位到元素,就直接執(zhí)行后續(xù)的代碼,反之等待10s后報錯誤信息 # 驗證元素是否出現(xiàn),傳入的參數(shù)都是元組類型的locator,如(By.ID, ‘kw') WebDriverWait(driver, 10 ).until(EC.visibility_of_element_located((By. ID , "kw" ))).send_keys( "好好學習" ) |
六、模塊用法匯總
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
#判斷當前頁面的title是否精確等于預期,返回布爾值 WebDriverWait(driver, 10 ).until(EC.title_is( "百度一下,你就知道" )) #判斷當前頁面的title是否包含預期字符串,返回布爾值 WebDriverWait(driver, 10 ).until(EC.title_contains( 'new' )) #判斷當前頁面的url是否精確等于預期,返回布爾值 WebDriverWait(driver, 10 ).until(EC.url_contains( 'https://www.baidu.com' )) #判斷當前頁面的url是否包含預期字符串,返回布爾值 WebDriverWait(driver, 10 ).until(EC.url_contains( 'baidu' )) #判斷當前頁面的url是否滿足字符串正則表達式匹配,返回布爾值 WebDriverWait(driver, 10 ).until(EC.url_matches( '.+baidu.+' )) #判斷元素是否出現(xiàn),只要有一個元素出現(xiàn),返回元素對象 WebDriverWait(driver, 10 ).until(EC.presence_of_element_located((By. ID , 'kw' ))) #判斷元素是否可見,返回元素對象 WebDriverWait(driver, 10 ).until(EC.visibility_of(driver.find_element(By. ID , 'kw' )) ) #判斷元素是否包含指定文本,返回布爾值 WebDriverWait(driver, 10 ).until(EC.text_to_be_present_in_element((By.NAME,'tj_trn ews '),' 新聞')) #判斷該frame是否可以switch進去,如果可以的話,返回True并且switch進去 WebDriverWait(driver, 10 ,).until(EC.frame_to_be_available_and_switch_to_it(By.xpa th, '//iframe' )) #判斷某個元素是否可見并且是可點擊的,如果是的就返回這個元素,否則返回False WebDriverWait(driver, 10 ).until(EC.element_to_be_clickable((By.NAME, 'tj_trnews' )) ) #判斷某個元素是否被選中,一般用在下拉列表 WebDriverWait(driver, 10 ).until(EC.element_to_be_selected(driver.find_element(By. xpath, '//input[@type="checkbox"]' ))) #判斷頁面上是否存在alert,如果有就切換到alert并返回alert的內(nèi)容 WebDriverWait(driver, 10 ).until(EC.alert_is_present()) |
到此這篇關(guān)于Python selenium的這三種等待方式一定要會!的文章就介紹到這了,更多相關(guān)selenium等待方式內(nèi)容請搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!
原文鏈接:https://blog.csdn.net/weixin_47197994/article/details/117706153