国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

網(wǎng)頁爬蟲 - Python+Selenium+PhantomJs爬蟲,如何取得新打開頁面的源碼?

瀏覽:118日期:2022-09-13 10:39:57

問題描述

我在做一個python爬蟲,使用了selenium庫和phantomjs瀏覽器。我在一個網(wǎng)頁中觸發(fā)了一個click事件打開了一個新的網(wǎng)頁,然后我用browser.page_source得到的卻是原來那個網(wǎng)頁非新打開網(wǎng)頁的源碼,請問我該如何取得新打開頁面的源碼呢?

問題解答

回答1:

如果鏈接打開了一個新標(biāo)簽頁的話,你的driver還是下默認(rèn)使用的還是當(dāng)前窗口,

Alternatively, you can pass a “window handle” to the “switch_to_window()” method. Knowing this, it’s possible to iterate over every open window like so:

for handle in driver.window_handles: driver.switch_to_window(handle)

比如,如果你的瀏覽器有幾個標(biāo)簽頁,那么window_handles就保存了對應(yīng)這幾個標(biāo)簽頁對應(yīng)的實例對象,所以如果你當(dāng)前只打開了一個網(wǎng)頁,那么你新打開的頁面就是 window_handles[1]轉(zhuǎn)換到那個頁面后,再獲取源碼。

回答2:

如果是在當(dāng)前窗口打開,有可能因為新頁面還沒有加載完成,到時拿不到新頁面的url和數(shù)據(jù),這里可以使用等待,并設(shè)置一些條件,確保新頁面加載完成再進行操作,代碼如下:

from selenium.webdriver.support.ui import WebDriverWait# 等待新頁面生成WebDriverWait(self.browser, 5).until( expected_conditions.presence_of_element_located((By.ID, 'username') )

標(biāo)簽: Python 編程
主站蜘蛛池模板: 怀来县| 宜兰县| 锡林郭勒盟| 托克逊县| 保山市| 桂阳县| 勃利县| 玛曲县| 西宁市| 油尖旺区| 且末县| 宝兴县| 广安市| 香河县| 昭觉县| 六枝特区| 讷河市| 汤阴县| 鹤庆县| 泗阳县| 会东县| 息烽县| 右玉县| 宁国市| 太和县| 三原县| 濮阳县| 呼图壁县| 柳河县| 平乐县| 平利县| 宁都县| 谢通门县| 利津县| 金山区| 鄢陵县| 和政县| 石景山区| 江西省| 永丰县| 阜新市|