方法1:用try…except…
def is_element_exsist1(driver, locator): """ :param driver: webdriver :param locator: tuple :return: bool """ try: driver.find_element(*locator) return True except Exception as msg: print("元素 %s 找不到:%s" %(locator, msg)) return False if __name__ == '__main__': driver = webdriver.Chrome() loc1 = ("id", "bibi") print(is_element_exsist1(driver,loc1))
方法2:用elements定義一組元素方法
def is_element_exsist2(driver, locator): """ :param driver: webdriver :param locator: tuple :return: bool """ eles = driver.find_elements(*locator) if len(eles) < 1: return False else: return True if __name__ == '__main__': driver = webdriver.Chrome() # loc1 = ("id", "bibi") # print(is_element_exsist1(driver,loc1)) loc2 = ("id", "bibi") print(is_element_exsist2(driver, loc2))
方法3:結合WebDriverWait和excepted_conditions判斷 (強烈推薦!!!) from selenium import webdriver from selenium.webdriver.support import expected_conditions as EC from selenium.webdriver.support.ui import WebDriverWait def is_element_exsist3(driver, locator): """ :param driver: webdriver :param locator: tuple :return: bool """ try: WebDriverWait(driver, 30, 1).until(EC.presence_of_element_located(locator)) return True except : return False if __name__ == '__main__': driver = webdriver.Chrome() # loc1 = ("id", "bibi") # print(is_element_exsist1(driver,loc1)) # loc2 = ("id", "bibi") # print(is_element_exsist2(driver, loc2)) loc3 = ("id", "bibi") print(is_element_exsist3(driver, loc3))
2、如何提高腳本的穩定性 類似問題還有: 用例在運行過程中經常會出現不穩定的情況,也就是說這次可以通過,下次就沒辦法通過了,如何去提升用例的穩定性? 如何提高selenium腳本的執行速度? selenium中如何保證操作元素的成功率?也就是說不管網絡加載慢還是快 如果一個元素今天能定位到,過幾天就定位不到了,只要這個頁面沒變過,說明定位方法是沒問題的。 優化方向: 不要右鍵復制xpath,自己寫相對路徑,多用id為節點查找 定位沒問題,第二個影響因素就是等待時間了。sleep等待盡量少用(影響執行時間)。driver.implicity_wait(10)隱式等待也不要用,不要以為是全局的就是好事。有些JS加載失敗時候會一直等,並且頁面跳轉時也無法識別。 定位元素方法重新封裝,結合WebDriverWait和excepted_conditions判斷元素方法,自己封裝一套定位元素方法 復制代碼 from selenium import webdriver from selenium.webdriver.support import expected_conditions as EC from selenium.webdriver.support.ui import WebDriverWait def find_ele(driver, locator, timeout=30): ele = WebDriverWait(driver, timeout, 1).until(EC.presence_of_element_located(locator)) return ele 復制代碼 3、如何定位動態元素 動態元素有2種情況,一個是屬性動態,比如id是動態的,定位時那就不要用id定位。還有一種情況動態的,那就是這個元素一會在頁面上方,一會在下方,飄忽不定的動態元素,定位方法一樣按F12,根據元素屬性定位(元素的tag、name的步伐屬性是不會變的,動的只是class屬性和styles屬性)。 4、如何通過子元素定位父元素 selenium里通過父元素定位子元素,可以通過二次定位來找到該元素。 ele=driver.find_element_by_id("parent").find_element_by_id("child") 5、子元素定位父元素 可以通過xpath的語法直接定位:.//*[@name="hell"]/.. 兩個點就是代表父級元素了。 6、一個元素明明定位到了,點擊無效(也沒報錯),如何解決? 使用js點擊,selenium有時點擊元素是會失效的 # js點擊 js = 'document.getElementById("baidu").click()' driver.execute_script(js) 7、隱藏元素 元素的屬性隱藏和顯示,主要是 type="hidden"和style="display:none;"屬性來控制的 定位 type="hidden"隱藏元素 ele=driver.find_element_by_id("p") print("打印元素信息:%s" %ele) 獲取元素屬性 print(ele.get_attribute("name")) 判斷元素是否隱藏 print(ele.is_displayed()) 隱藏元素用普通定位方法,事實上是定位到了。 8、操作隱藏元素 隱藏元素可以正常定位到,只是不能操作。操作元素是click,clear,send_keys這些方法。 隱藏輸入框元素輸入文本:隱藏元素用send_keys()方法會拋異常 ElementNotVisibleException。這個報錯是說元素不可見,不可以被操作。 JS操作隱藏元素 selenium是無法操作隱藏元素的(但是能正常定位到),本身這個框架就是設計如此。如果非要去操作隱藏元素,那就用js的方法去操作,selenium提供了一個入口可以執行js腳本。 js和selenium不同,只要頁面上有的元素(在dom里面的)都能正常的操作。 js點擊hidden元素 js = 'document.getElementById("baidu").click()' driver.execute_script(js) 運行完之后,會發現頁面正常點擊了 備注:百度搜到的可能方法是先用js去掉hidden屬性,再用selenium操作,這樣有點多此一舉了。既然都已經會用js了,何必不一次性到位直接click呢?