校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > python實現selenium網絡爬蟲的方法小結

python實現selenium網絡爬蟲的方法小結

熱門標簽:云南地圖標注 賓館能在百度地圖標注嗎 汕頭電商外呼系統供應商 crm電銷機器人 南京crm外呼系統排名 北京外呼電銷機器人招商 鄭州智能外呼系統中心 電銷機器人 金倫通信 400電話 申請 條件

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

1.selenium初始化

方法一:會打開網頁

# 該方法會打開goole網頁
from selenium import webdriver
url = '網址'
driver = webdriver.Chrome()
driver.get(url)
driver.maximize_window() # 實現窗口最大化

方法二:不會打開網頁

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

driver = webdriver.Chrome()出錯是因為沒有chromedriver.exe這個文件

2.元素定位

在selenium中,可以有多種方法對元素進行定位,個人通常喜歡用Xpath和selector來定位元素,這樣就不用一個一個的去找節點,直接在網頁上定位到元素復制就行。

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() # 通過文本內容定位
driver.find_element_by_partial_link_text()
driver.find_element_by_xpath() # 通過Xpath語法定位
driver.find_element_by_css_selector() # 通過選擇器定位

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

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

3.建立點擊事件

因為有些網站的需求,需建立點擊事件,
如下圖的這種時間選擇,需要設置點擊和輸入內容,設置的方法也很簡單。

driver.find_element_by_css_selector('').click() # 點擊
driver.find_element_by_css_selector('').send_keys('2021-3-9') # 輸入內容

4.切換窗口

有些網站點擊之后會產生新窗口,這時就需要進行窗口的切換才能進行元素定位

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

5.iframe問題

有些網站會采用iframe來編寫頁面,這時就需要進入到iframe才可以獲取元素,一般有多少個iframe就需要進入多少個iframe。

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

到此這篇關于python實現selenium網絡爬蟲的文章就介紹到這了,更多相關python selenium網絡爬蟲內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python selenium模擬網頁點擊爬蟲交管12123違章數據
  • python爬蟲之利用Selenium+Requests爬取拉勾網
  • python爬蟲selenium模塊詳解
  • python爬蟲利用selenium實現自動翻頁爬取某魚數據的思路詳解
  • Python爬蟲之Selenium實現關閉瀏覽器
  • Python爬蟲中Selenium實現文件上傳
  • Python爬蟲之Selenium下拉框處理的實現
  • 教你如何使用Python selenium

標簽:西寧 昆明 懷化 石家莊 文山 浙江 錫林郭勒盟 梅州

巨人網絡通訊聲明:本文標題《python實現selenium網絡爬蟲的方法小結》,本文關鍵詞  python,實現,selenium,網絡,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python實現selenium網絡爬蟲的方法小結》相關的同類信息!
  • 本頁收集關于python實現selenium網絡爬蟲的方法小結的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 彭水| 乌兰察布市| 达州市| 阜康市| 高安市| 抚顺县| 普陀区| 海盐县| 屯门区| 福安市| 鄯善县| 乐都县| 巴彦县| 祁东县| 浦江县| 静宁县| 青河县| 黄陵县| 安溪县| 济宁市| 鹤峰县| 马关县| 嘉峪关市| 若尔盖县| 金坛市| 铁岭县| 洞头县| 和田市| 榆树市| 东乡族自治县| 游戏| 望城县| 新龙县| 桃园县| 中牟县| 团风县| 得荣县| 车致| 长寿区| 淮南市| 邮箱|