Python selenium的這三種等待方式一定要會!
一、為什麼要使用等待?
在自動化測試腳本的運行過程中,webdriver操作瀏覽器的時候,對於元素的定位是有一定的超時
時間,大致在1-3秒
如果這個時間內仍然定位不到元素,就會拋出異常,中止腳本執行
我們可以通過在腳本中設置等待的方式來避免由於網絡延遲或瀏覽器卡頓導致的偶然失敗
二、常用的三種等待方式
- 強制等待
- 隱式等待
- 顯示等待
三、強制等待
利用time模塊的sleep方法來實現,最簡單粗暴的等待方法
強制等待,不管你瀏覽器是否加載完成,都得給我等待3秒,3秒一到,繼續執行下面的代碼
# -*- 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()
弊端
不建議用這種等待方法,嚴重影響代碼的執行速度
四、隱式等待
implicitly_wait()方法用來等待頁面加載完成(直觀的就是瀏覽器tab頁上的小圈圈轉完)網頁加載
完成則執行下一步
隱式等待隻需要聲明一次,一般在打開瀏覽器後進行聲明
聲明之後對整個drvier的生命周期都有效,後面不用重復聲明
# -*- 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()
弊端
程序會一直等待整個頁面加載完成,直到超時
有時候我需要的那個元素早就加載完成瞭,隻是頁面上有個別其他元素加載特別慢,我仍要等待頁
面全部加載完成才能執行下一步
五、顯示等待
WebDriverWait,配合該類的until()和until_not()方法,就能夠根據判斷條件而進行靈活地等待瞭
它主要的意思就是:程序每隔xx秒看一眼,如果條件成立瞭,則執行下一步
否則繼續等待,直到超過設置的最長時間,然後拋出TimeoutException
顯示等待必須在每個需要等待的元素前面進行聲明
# 導入模塊 from selenium.webdriver.support.wait import WebDriverWait
四個參數
driver:瀏覽器驅動
timeout:等待時間
poll_frequency:檢測的間隔時間,默認0.5s
ignored_exceptions:超時後的異常信息,默認拋出NoSuchElementException
expected_conditions
expected_conditions是selenium的一個模塊
包含一系列可用於判斷的條件
可以對網頁上元素是否存在,可點擊等等進行判斷,一般用於斷言或與WebDriverWait配合使用
from selenium.webdriver.support import expected_conditions as EC
# -*- 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,等待過程中如果定位到元素,就直接執行後續的代碼,反之等待10s後報錯誤信息 # 驗證元素是否出現,傳入的參數都是元組類型的locator,如(By.ID, ‘kw') WebDriverWait(driver, 10).until(EC.visibility_of_element_located((By.ID, "kw"))).send_keys("好好學習")
六、模塊用法匯總
#判斷當前頁面的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.+')) #判斷元素是否出現,隻要有一個元素出現,返回元素對象 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的內容 WebDriverWait(driver,10).until(EC.alert_is_present())
到此這篇關於Python selenium的這三種等待方式一定要會!的文章就介紹到這瞭,更多相關selenium等待方式內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- python自動化測試selenium核心技術等待條件教程
- python自動化測試selenium核心技術三種等待方式詳解
- 全網最全python庫selenium自動化使用詳細教程
- python自動化測試selenium核心技術處理彈框
- Python爬蟲之Selenium庫的使用方法