主頁(yè) > 知識(shí)庫(kù) > python實(shí)現(xiàn)selenium網(wǎng)絡(luò)爬蟲的方法小結(jié)

python實(shí)現(xiàn)selenium網(wǎng)絡(luò)爬蟲的方法小結(jié)

熱門標(biāo)簽:呼叫中心市場(chǎng)需求 語(yǔ)音系統(tǒng) 電話運(yùn)營(yíng)中心 百度AI接口 硅谷的囚徒呼叫中心 客戶服務(wù) Win7旗艦版 企業(yè)做大做強(qiáng)

selenium最初是一個(gè)自動(dòng)化測(cè)試工具,而爬蟲中使用它主要是為了解決requests無(wú)法直接執(zhí)行JavaScript代碼的問(wèn)題,selenium本質(zhì)是通過(guò)驅(qū)動(dòng)瀏覽器,完全模擬瀏覽器的操作,比如跳轉(zhuǎn)、輸入、點(diǎn)擊、下拉等,來(lái)拿到網(wǎng)頁(yè)渲染之后的結(jié)果,可支持多種瀏覽器,這里只用到谷歌瀏覽器。

1.selenium初始化

方法一:會(huì)打開網(wǎng)頁(yè)

# 該方法會(huì)打開goole網(wǎng)頁(yè)
from selenium import webdriver
url = '網(wǎng)址'
driver = webdriver.Chrome()
driver.get(url)
driver.maximize_window() # 實(shí)現(xiàn)窗口最大化

方法二:不會(huì)打開網(wǎng)頁(yè)

# 該方法會(huì)隱式打開goole網(wǎng)頁(yè)
from selenium import webdriver
url = '網(wǎng)址'
driver = webdriver.ChromeOptions()
driver.add_argument("headless")
driver = webdriver.Chrome(options=driver)
driver.get(url)

driver = webdriver.Chrome()出錯(cuò)是因?yàn)闆]有chromedriver.exe這個(gè)文件

2.元素定位

在selenium中,可以有多種方法對(duì)元素進(jìn)行定位,個(gè)人通常喜歡用Xpath和selector來(lái)定位元素,這樣就不用一個(gè)一個(gè)的去找節(jié)點(diǎn),直接在網(wǎng)頁(yè)上定位到元素復(fù)制就行。

driver.find_element_by_id() # 通過(guò)元素ID定位
driver.find_element_by_name() # 通過(guò)元素Name定位
driver.find_element_by_class_name() # 通過(guò)類名定位
driver.find_element_by_tag_name() # 通過(guò)元素TagName定位
driver.find_element_by_link_text() # 通過(guò)文本內(nèi)容定位
driver.find_element_by_partial_link_text()
driver.find_element_by_xpath() # 通過(guò)Xpath語(yǔ)法定位
driver.find_element_by_css_selector() # 通過(guò)選擇器定位

注:若尋找多個(gè)元素,要記得用復(fù)數(shù)來(lái)選擇(element改為elements)

# 例如
[i.text for i in driver.find_elements_by_xpath()]

3.建立點(diǎn)擊事件

因?yàn)橛行┚W(wǎng)站的需求,需建立點(diǎn)擊事件,
如下圖的這種時(shí)間選擇,需要設(shè)置點(diǎn)擊和輸入內(nèi)容,設(shè)置的方法也很簡(jiǎn)單。

driver.find_element_by_css_selector('').click() # 點(diǎn)擊
driver.find_element_by_css_selector('').send_keys('2021-3-9') # 輸入內(nèi)容

4.切換窗口

有些網(wǎng)站點(diǎn)擊之后會(huì)產(chǎn)生新窗口,這時(shí)就需要進(jìn)行窗口的切換才能進(jìn)行元素定位

win = driver.window_handles # 獲取當(dāng)前瀏覽器的所有窗口
driver.switch_to.window(win[-1]) # 切換到最后打開的窗口
driver.close() # 關(guān)閉當(dāng)前窗口
driver.switch_to.window(win[0]) # 切換到最初的窗口

5.iframe問(wèn)題

有些網(wǎng)站會(huì)采用iframe來(lái)編寫頁(yè)面,這時(shí)就需要進(jìn)入到iframe才可以獲取元素,一般有多少個(gè)iframe就需要進(jìn)入多少個(gè)iframe。

# 有兩個(gè)iframe,需逐步進(jìn)入
iframe1 = driver.find_element_by_xpath('')
driver.switch_to.frame(iframe1)
iframe2 = driver.find_element_by_xpath('')
driver.switch_to.frame(iframe2)

到此這篇關(guān)于python實(shí)現(xiàn)selenium網(wǎng)絡(luò)爬蟲的文章就介紹到這了,更多相關(guān)python selenium網(wǎng)絡(luò)爬蟲內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python selenium模擬網(wǎng)頁(yè)點(diǎn)擊爬蟲交管12123違章數(shù)據(jù)
  • python爬蟲之利用Selenium+Requests爬取拉勾網(wǎng)
  • python爬蟲selenium模塊詳解
  • python爬蟲利用selenium實(shí)現(xiàn)自動(dòng)翻頁(yè)爬取某魚數(shù)據(jù)的思路詳解
  • Python爬蟲之Selenium實(shí)現(xiàn)關(guān)閉瀏覽器
  • Python爬蟲中Selenium實(shí)現(xiàn)文件上傳
  • Python爬蟲之Selenium下拉框處理的實(shí)現(xiàn)
  • 教你如何使用Python selenium

標(biāo)簽:長(zhǎng)沙 海南 濟(jì)南 崇左 山西 安康 喀什 山西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python實(shí)現(xiàn)selenium網(wǎng)絡(luò)爬蟲的方法小結(jié)》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266