python實(shí)現(xiàn)selenium網(wǎng)絡(luò)爬蟲的方法小結(jié)
selenium最初是一個(gè)自動(dòng)化測(cè)試工具,而爬蟲中使用它主要是為了解決requests無法直接執(zhí)行JavaScript代碼的問題,selenium本質(zhì)是通過驅(qū)動(dòng)瀏覽器,完全模擬瀏覽器的操作,比如跳轉(zhuǎn)、輸入、點(diǎn)擊、下拉等,來拿到網(wǎng)頁渲染之后的結(jié)果,可支持多種瀏覽器,這里只用到谷歌瀏覽器。
1.selenium初始化方法一:會(huì)打開網(wǎng)頁# 該方法會(huì)打開goole網(wǎng)頁from selenium import webdriverurl = ’網(wǎng)址’driver = webdriver.Chrome()driver.get(url)driver.maximize_window() # 實(shí)現(xiàn)窗口最大化方法二:不會(huì)打開網(wǎng)頁
# 該方法會(huì)隱式打開goole網(wǎng)頁from selenium import webdriverurl = ’網(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來定位元素,這樣就不用一個(gè)一個(gè)的去找節(jié)點(diǎn),直接在網(wǎng)頁上定位到元素復(fù)制就行。
driver.find_element_by_id() # 通過元素ID定位driver.find_element_by_name() # 通過元素Name定位driver.find_element_by_class_name() # 通過類名定位driver.find_element_by_tag_name() # 通過元素TagName定位driver.find_element_by_link_text() # 通過文本內(nèi)容定位driver.find_element_by_partial_link_text()driver.find_element_by_xpath() # 通過Xpath語法定位driver.find_element_by_css_selector() # 通過選擇器定位
注:若尋找多個(gè)元素,要記得用復(fù)數(shù)來選擇(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ǎng)站會(huì)采用iframe來編寫頁面,這時(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)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 基于 Python 實(shí)踐感知器分類算法2. Python如何批量生成和調(diào)用變量3. ASP.NET MVC實(shí)現(xiàn)橫向展示購物車4. 通過CSS數(shù)學(xué)函數(shù)實(shí)現(xiàn)動(dòng)畫特效5. ASP.Net Core對(duì)USB攝像頭進(jìn)行截圖6. python利用opencv實(shí)現(xiàn)顏色檢測(cè)7. ASP.Net Core(C#)創(chuàng)建Web站點(diǎn)的實(shí)現(xiàn)8. Python 中如何使用 virtualenv 管理虛擬環(huán)境9. Python獲取B站粉絲數(shù)的示例代碼10. windows服務(wù)器使用IIS時(shí)thinkphp搜索中文無效問題
