国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

瀏覽:24日期:2022-06-25 11:59:32

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

1.selenium初始化方法一:會打開網(wǎng)頁

# 該方法會打開goole網(wǎng)頁from selenium import webdriverurl = ’網(wǎng)址’driver = webdriver.Chrome()driver.get(url)driver.maximize_window() # 實(shí)現(xiàn)窗口最大化方法二:不會打開網(wǎng)頁

# 該方法會隱式打開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()出錯是因?yàn)闆]有chromedriver.exe這個文件

2.元素定位

在selenium中,可以有多種方法對元素進(jìn)行定位,個人通常喜歡用Xpath和selector來定位元素,這樣就不用一個一個的去找節(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() # 通過選擇器定位

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

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

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

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

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

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

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)擊之后會產(chǎn)生新窗口,這時就需要進(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)站會采用iframe來編寫頁面,這時就需要進(jìn)入到iframe才可以獲取元素,一般有多少個iframe就需要進(jìn)入多少個iframe。

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

# 有兩個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)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 欧洲freexxxx性| 久久久精品久久久久久久久久久 | 亚洲午夜精品一区二区 | www欧美com| 久久精品国产91久久综合麻豆自制 | 人成18亚洲资源在线 | www.av视频在线 | 在线免费一级片 | 91伦理视频 | 亚洲精品成人久久久影院 | 亚洲视频在线免费播放 | 中文字幕一区二区在线观看 | 亚洲一级片在线播放 | 成人精品一区二区不卡视频 | 成人亚洲精品一区 | 国产精品九九久久一区hh | 一级特黄牲大片免费视频 | 日本成人不卡视频 | 欧美成人高清免费大片观看 | 手机在线精品视频每日更新 | 久草成人在线视频 | 性色午夜视频免费男人的天堂 | 殴美一级 | 日本一级高清不卡视频在线 | 亚洲成人7777 | 久久国产成人精品麻豆 | 中文字幕精品一区二区精品 | 国产无套视频在线观看香蕉 | 国产精品私人玩物在线观看 | 91chinesevideo在线观看 | 欧洲欧美成人免费大片 | 亚洲欧美在线免费 | 三级网站免费看 | 亚洲精品国产第一区二区多人 | 99国产精品免费视频观看 | 日韩欧美第一页 | 黄网站色视频免费观看w | 日韩在线欧美在线 | 久久精品国产线看观看亚洲 | 在线播放免费播放av片 | 日韩高清在线不卡 |