from selenium import webdriver driver=webdriver.Chrome() driver.set_page_load_timeout(5) driver.set_script_timeout(5)#這兩種設置都進行才有效
try: d.get(s) except: d.execute_script('window.stop()')#這句話好像沒什么軟用
可以在頁面停止加載后繼續操作了
driver.set_page_load_timeout(5)這玩意一設置,沒問題,5秒后網頁確實停止了,但是driver也死了,不管運行什么都是timeout,還說try一下,driver是死透了,只能重新來
不知道是selenium更新了還是他自己沒測試還是chrome更新了,現在這么設置就是找死的
注意:使用set_page_load_timeout時候,當頁面未加載出任何東西的時候(往往是html源碼未加載),因為超時而停止,會導致driver失效,
后面的driver都不能操作,所以超時設置應該至少保證頁面內容加載出來一部分,設置超時不宜過短,如下圖在頁面此種狀態下停止加載后driver失效。
不錯,是有人也說了,不能設置太短,會失效,但是我可以說,你設置5分鍾照樣失效,只要超時一次,driver就完蛋,直接翻車
接下來是另一個方法
# coding = utf-8 from selenium import webdriver from selenium.webdriver.support.wait import WebDriverWait import time driver = webdriver.Chrome() class button(): def __call__(self, driver): if driver.find_element_by_id('js_love_url'): return True else: return False driver.implicitly_wait(60) time_start = time.time() driver.get('https://www.163.com/') # driver.find_element_by_id('js_love_url').click() WebDriverWait(driver,2,0.5).until(button()) time_end = time.time() print('access time is : ', time_end - time_start) time.sleep(2) driver.quit()
用WebDriverWait進行操作,不過我測試下來,driver.get()不執行完,下面的代碼根本就不會執行,所以還是不行
找了各種方法,各種操作,都失敗了,總算今天找到了正確的方法
原理非常簡單:driver.get()這個操作,改成不阻塞的就行了,這樣打開網頁就操作完成了,不需要等他加載
下面我可以直接等待需要的元素出現即可進行操作
配置也是很簡單
from selenium import webdriver from selenium.webdriver.common.desired_capabilities import DesiredCapabilities #get直接返回,不再等待界面加載完成 desired_capabilities = DesiredCapabilities.CHROME desired_capabilities["pageLoadStrategy"] = "none"driver = webdriver.Chrome(executable_path='chromedriver.exe')
配置一個參數,就是頁面加載策略,系統默認是等待,就是等他加載完,直接設置成none,就是不等待,這樣就是get操作完后直接就是結束了
不影響下面的操作,這樣就可以愉快的玩耍了