標題目錄
- 一、前言
- 二、強制等待
- 三、隱式等待
- 四、顯式等待
- 五、最后
一、前言
1、強制等待是sleep,強烈不推薦,設定的時間太固定,如果是模擬器等待3秒,真機可能只需要等待2秒,
2、driver.implicitly.wat(timeout) ,貫穿全部元素的等待,只需要設定一次即可,通常是在創建driver的時候后的代碼運行,是dom建立之后的等待,
3、顯式等待是在客戶端的等待:參考連個包和一個例子
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions
WebDriverWait(self.driver,10).until(expected_conditions.element_to_be_clickable(loca
tor))
二、強制等待
強制等待,執行緒休眠一定時間,
import time time.sleep(3)
三、隱式等待
隱式等待,就是在創建driver時,設定全域元素等待超時時間,
當要查找元素,而這個元素沒有馬上出現時,告訴 WebDriver 查詢 Dom 一定時間,實際上瀏覽器會在你自己設定的時間內不斷的重繪頁面去尋找我們需要的元素,
默認值是 0.5秒,但是設定之后,這個時間將在WebDriver 物件實體整個生命周期都起作用,(處理 Table 物件時,需要將此設定為默認值)
self.driver.implicitly_wait(10)
設定等待時長為10秒,首先這10秒并非一個固定的等待時間,它并不影響腳本的執行速度,其次,它并不針對頁面上的某一元素進行等待,
當腳本執行到某個元素定位是,如果元素可以定位,則繼續執行,如果元素定位不到,則它將以輪詢的方式不斷地判斷元素是否被定位到,
假設在第六秒定位到了元素則繼續執行,若直到超出設定的時長10秒還沒有定位到元素,則拋出例外,
四、顯式等待
1、顯式等待的簡介
(1)顯式等待與隱式等待相對,顯式等待必須在每一個需要等待的元素前面進行宣告,
(2)是針對某個特定的元素設定等待時間,在設定時間內,默認每隔一段時間檢測一次當前某個元素是否存在,
(3)如果在規定的時間內找到元素,則直接執行,即找到元素就執行相關操作,
(4)如果超過設定時間檢測不到就拋出例外,默認檢測頻率為0.5s,默認拋出的例外時NoSuchElementException,
(5)用到的兩個常用類:
WebDriverWait
expected_condition
2、為什么要用顯式等待,為什么隱式等待無法替代顯式等待?
(1)顯式等待可以等待動態加載的ajax元素,需要配合expected_condition來檢查條件,
(2)一般頁面上元素的呈現順序是:
首先出現title,
然后是dom樹的出現,presence還不完整,dom樹出現就是隱式等待了,但此時的元素可能還沒有是可點擊的狀態,所以只用隱式等待,使用click方法,肯定會報錯的,
css出現:可見visbility,
js的出現,js特效執行:可點擊clickable,
(3)html檔案是自上而下加載的,
(4)js檔案加載會阻塞html內容的加載,有些js異步加載的方式來完成js的加載 樣式表下載完成之后跟之前的樣式表一起進行決議,會對之前那的與元素重新渲染,
(5)presence-visibility-clickabe,元素出現-可見-可點擊,是元素的三個性質,當DOM樹出現時,定位元素可能已經顯示出來了,但是可見和可點擊的屬性可能還沒加載出來,這時候元素的一些方法是不可用的,比如 element.click() ,要等到js渲染出來以后,元素的click屬性才可以用,
對應 element.is_displayed()
對應 element.is_selected()
對應 element.is_enabled()
3、js的同步加載和異步加載
同步加載:同步模式,又稱阻塞模式,會阻止瀏覽器的后續處理,停止了后續的決議,因此停止了后續的檔案加載(如影像)、渲染、代碼執行,
異步加載:異步加載又叫非阻塞,瀏覽器在下載執行 js 同時,還會繼續進行后續頁面的處理,
4、WebDriverWait用法
WebDriverWait(self, driver, timeout, poll_frequency=POLL_FREQUENCY,
ignored_exceptions=None)
driver:瀏覽器驅動
timeout:超時時間,單位秒
poll_frequency:檢查的間隔步長,默認是0.5s
ignored_exceptions:超時最后的拋出的例外,默認是NoSuchElementException
通常我們只會用到driver和timeout
WebDriverWait().unti(self, method, message=’’) or until_not()的方法:
(1)method:在等待期間,每個一段時間(__init__中的poll_frequency)呼叫這個傳入的方法,直到回傳值不是False
(2)message:如果超時,拋出
TimeoutException,將message傳入例外
(3)until not:是當某個元素小時或什么條件則繼續執行,引數也相同
5、expected_conditions類
appium直接幫我們封裝好了類,只需要傳引數即可,比如我們使用的是click(),只需要判斷這個元素是否可點擊屬性才繼續點擊,
用法:expected_conditions.element_to_be_clickable(locator) ,其中locator就是:(By.ID,
“com.xueqiu.android:id/tv_search”)
常用的幾個如下:
expected_conditions.element_to_be_clickable :元素是否可點擊
expected_conditions.presence_of_element_located :元素是否被加到dom樹里面
expected_conditions.visibility_of_element_located :元素是否可見
6、lambda獲取元素
#可以獲取到元素 element = WebDriverWait(self.driver, 10).until(lambda x: x.find_element(By.XPATH,'//* [@text="我的"]')) #這里找到元素后,不用等待,實測證明過了 element.click()
顯式等待
使webdriver等待某個條件成立時繼續執行,否則在最大時長時拋出超時溢位,
from selenium.webdriver.support.wait import WebDriverWait from selenium.webdriver.support import expected_conditions as EC def find_element(self,*loc): '''尋找元素''' try: WebDriverWait(self.driver,10).until(EC.visibility_of_element_located(loc)) #顯示 等待 return self.driver.find_element(*loc) except: print('%s頁面未找到元素'% loc)
until:
'''隱式等待和顯示等待都存在時,超時時間取二者中較大的''' locator = (By.ID,'kw') driver.get(base_url) WebDriverWait(driver,10).until(EC.title_is(u"百度一下,你就知道")) '''判斷title,回傳布林值''' WebDriverWait(driver,10).until(EC.title_contains(u"百度一下")) '''判斷title,回傳布林值''' WebDriverWait(driver,10).until(EC.presence_of_element_located((By.ID,'kw'))) '''判斷某個元素是否被加到了dom樹里,并不代表該元素一定可見,如果定位到就回傳WebElement''' WebDriverWait(driver,10).until(EC.visibility_of_element_located((By.ID,'su'))) '''判斷某個元素是否被添加到了dom里并且可見,可見代表元素可顯示且寬和高都大于0''' WebDriverWait(driver,10).until(EC.visibility_of(driver.find_element(by=By.ID,value=https://www.cnblogs.com/flowToken1024532/p/'kw')) ) '''判斷元素是否可見,如果可見就回傳這個元素''' WebDriverWait(driver,10).until(EC.presence_of_all_elements_located((By.CSS_SELECTOR,'.mna v'))) '''判斷是否至少有1個元素存在于dom樹中,如果定位到就回傳串列''' WebDriverWait(driver,10).until(EC.visibility_of_any_elements_located((By.CSS_SELECTOR,'.m nav'))) '''判斷是否至少有一個元素在頁面中可見,如果定位到就回傳串列''' WebDriverWait(driver,10).until(EC.text_to_be_present_in_element((By.XPATH,"//* [@id='u1']/a[8]"),u'設定')) '''判斷指定的元素中是否包含了預期的字串,回傳布林值''' WebDriverWait(driver,10).until(EC.text_to_be_present_in_element_value((By.CSS_SELECTOR,'# su'),u'百度一下')) '''判斷指定元素的屬性值中是否包含了預期的字串,回傳布林值''' #WebDriverWait(driver,10).until(EC.frame_to_be_available_and_switch_to_it(locator)) '''判斷該frame是否可以switch進去,如果可以的話,回傳True并且switch進去,否則回傳False''' #注意這里并沒有一個frame可以切換進去 WebDriverWait(driver,10).until(EC.invisibility_of_element_located((By.CSS_SELECTOR,'#swfE veryCookieWrap'))) '''判斷某個元素在是否存在于dom或不可見,如果可見回傳False,不可見回傳這個元素''' #注意#swfEveryCookieWrap在此頁面中是一個隱藏的元素 WebDriverWait(driver,10).until(EC.element_to_be_clickable((By.XPATH,"//* [@id='u1']/a[8]"))).click() '''判斷某個元素中是否可見并且是enable的,代表可點擊''' driver.find_element_by_xpath("//*[@id='wrapper']/div[6]/a[1]").click() #WebDriverWait(driver,10).until(EC.element_to_be_clickable((By.XPATH,"//* [@id='wrapper']/div[6]/a[1]"))).click() #WebDriverWait(driver,10).until(EC.staleness_of(driver.find_element(By.ID,'su'))) '''等待某個元素從dom樹中移除''' #這里沒有找到合適的例子 WebDriverWait(driver,10).until(EC.element_to_be_selected(driver.find_element(By.XPATH,"// *[@id='nr']/option[1]"))) '''判斷某個元素是否被選中了,一般用在下拉串列''' WebDriverWait(driver,10).until(EC.element_selection_state_to_be(driver.find_element(By.XP ATH,"//*[@id='nr']/option[1]"),True)) '''判斷某個元素的選中狀態是否符合預期''' WebDriverWait(driver,10).until(EC.element_located_selection_state_to_be((By.XPATH,"//* [@id='nr']/option[1]"),True)) '''判斷某個元素的選中狀態是否符合預期''' driver.find_element_by_xpath(".//*[@id='gxszButton']/a[1]").click() instance = WebDriverWait(driver,10).until(EC.alert_is_present()) '''判斷頁面上是否存在alert,如果有就切換到alert并回傳alert的內容''' print instance.text instance.accept() driver.close()

五、最后
對軟體測驗、介面測驗、自動化測驗、軟體測驗零基礎入門、性能測驗、LR腳本開發、python自動化全堆疊、面試經驗感興趣可以175317069,群內會有不定期的發放免費的資料鏈接,如果你有好的學習也資料可以私聊發我,我會注明出處之后分享給大家,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/16217.html
標籤:其他
