在自動化測試腳本的運行過程中,webdriver操作瀏覽器的時候,對于元素的定位是有一定的超時
時間,大致在1-3秒
如果這個時間內(nèi)仍然定位不到元素,就會拋出異常,中止腳本執(zhí)行
我們可以通過在腳本中設(shè)置等待的方式來避免由于網(wǎng)絡(luò)延遲或瀏覽器卡頓導(dǎo)致的偶然失敗
利用time模塊的sleep方法來實現(xiàn),最簡單粗暴的等待方法
強(qiáng)制等待,不管你瀏覽器是否加載完成,都得給我等待3秒,3秒一到,繼續(xù)執(zhí)行下面的代碼
# -*- coding: utf-8 -*- # @Author : 程序員一凡 import time from selenium import webdriver driver = webdriver.Chrome() # 打開百度首頁 driver.get(r'https://www.baidu.com/') # 強(qiáng)制等待3秒 time.sleep(3) driver.find_element_by_css_selector("#kw").send_keys("selenium") # 退出 driver.quit()
弊端
不建議用這種等待方法,嚴(yán)重影響代碼的執(zhí)行速度
implicitly_wait()方法用來等待頁面加載完成(直觀的就是瀏覽器tab頁上的小圈圈轉(zhuǎn)完)網(wǎng)頁加載
完成則執(zhí)行下一步
隱式等待只需要聲明一次,一般在打開瀏覽器后進(jìn)行聲明
聲明之后對整個drvier的生命周期都有效,后面不用重復(fù)聲明
# -*- 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ù)判斷條件而進(jìn)行靈活地等待了
它主要的意思就是:程序每隔xx秒看一眼,如果條件成立了,則執(zhí)行下一步
否則繼續(xù)等待,直到超過設(shè)置的最長時間,然后拋出TimeoutException
顯示等待必須在每個需要等待的元素前面進(jìn)行聲明
# 導(dǎo)入模塊 from selenium.webdriver.support.wait import WebDriverWait
四個參數(shù)
driver:瀏覽器驅(qū)動
timeout:等待時間
poll_frequency:檢測的間隔時間,默認(rèn)0.5s
ignored_exceptions:超時后的異常信息,默認(rèn)拋出NoSuchElementException
expected_conditions
expected_conditions是selenium的一個模塊
包含一系列可用于判斷的條件
可以對網(wǎng)頁上元素是否存在,可點擊等等進(jìn)行判斷,一般用于斷言或與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,等待過程中如果定位到元素,就直接執(zhí)行后續(xù)的代碼,反之等待10s后報錯誤信息 # 驗證元素是否出現(xiàn),傳入的參數(shù)都是元組類型的locator,如(By.ID, ‘kw') WebDriverWait(driver, 10).until(EC.visibility_of_element_located((By.ID, "kw"))).send_keys("好好學(xué)習(xí)")
#判斷當(dāng)前頁面的title是否精確等于預(yù)期,返回布爾值 WebDriverWait(driver,10).until(EC.title_is("百度一下,你就知道")) #判斷當(dāng)前頁面的title是否包含預(yù)期字符串,返回布爾值 WebDriverWait(driver,10).until(EC.title_contains('new')) #判斷當(dāng)前頁面的url是否精確等于預(yù)期,返回布爾值 WebDriverWait(driver,10).until(EC.url_contains('https://www.baidu.com')) #判斷當(dāng)前頁面的url是否包含預(yù)期字符串,返回布爾值 WebDriverWait(driver,10).until(EC.url_contains('baidu')) #判斷當(dāng)前頁面的url是否滿足字符串正則表達(dá)式匹配,返回布爾值 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進(jìn)去,如果可以的話,返回True并且switch進(jìn)去 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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
標(biāo)簽:牡丹江 南寧 揚州 楊凌 聊城 六盤水 迪慶 撫州
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python selenium的這三種等待方式一定要會!》,本文關(guān)鍵詞 Python,selenium,的,這,三種,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。