91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Python網(wǎng)絡(luò)爬蟲Selenium的簡(jiǎn)單使用

冬至子 ? 來源:宓海 ? 作者:宓海 ? 2023-11-14 14:44 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

Python網(wǎng)絡(luò)爬蟲-Selenium

想要學(xué)習(xí)爬蟲,如果比較詳細(xì)的了解web開發(fā)的前端知識(shí)會(huì)更加容易上手,時(shí)間不夠充裕,僅僅了解html的相關(guān)知識(shí)也是夠用的。

準(zhǔn)備工作:

使用它肯定先要安裝它,對(duì)于Selenium的安裝推薦使用pip,十分方便。因?yàn)槲沂褂玫氖枪雀铻g覽器,使用前需要先配置相應(yīng)的ChromeDriver,在此放出對(duì)應(yīng)谷歌瀏覽器對(duì)應(yīng)的80版本的ChromeDriver。地址 :點(diǎn)擊下載提取碼:sz2s
至于如何去安裝配置,網(wǎng)絡(luò)上有很多教程,在此不做贅述。

簡(jiǎn)要功能:

使用Selenium可以驅(qū)動(dòng)瀏覽器執(zhí)行特定操作,如點(diǎn)擊,下拉等等,同時(shí)也能直接抓取網(wǎng)頁源代碼,即做到可見即可爬。

1.訪問頁面

通過下面這幾行代碼可以實(shí)現(xiàn)瀏覽器的驅(qū)動(dòng)并獲取網(wǎng)頁源碼,非常便捷。

from selenium import webdriver

browser = webdriver.Chrome()  #聲明瀏覽器對(duì)象
browser.get('https://www.baidu.com')
print(browser.page_source)  #打印網(wǎng)頁源碼
browser.close()			#關(guān)閉瀏覽器

2.查找節(jié)點(diǎn)

selenium可以驅(qū)動(dòng)瀏覽器完成各種操作,但進(jìn)行模擬點(diǎn)擊,填寫表單時(shí),我們總要知道這些輸入框,點(diǎn)擊按鈕在哪里,所以需要獲取相對(duì)的節(jié)點(diǎn)。總共有其中尋找節(jié)點(diǎn)的方法,在此給出一個(gè)非常全面的學(xué)習(xí)查找節(jié)點(diǎn)的教程。

=單個(gè)節(jié)點(diǎn)=
下面以百度首頁為例。通過查找源碼,我們可以發(fā)現(xiàn)對(duì)應(yīng)搜索文本框的class,name,id等屬性名。

圖片

from selenium import webdriver

browser = webdriver.Chrome()
browser.get('https://www.baidu.com')
input = browser.find_element_by_id('kw')		#獲取搜索框位置
input.send_keys('Python')    	#輸入內(nèi)容

運(yùn)行代碼得到如下內(nèi)容,此時(shí)我們只是輸入,并未進(jìn)行其他操作。

圖片

=多個(gè)節(jié)點(diǎn)=

如果查找目標(biāo)在網(wǎng)頁中只有一個(gè),使用find_element()方法就可了。如果有多個(gè),舉個(gè)例子,如查找多個(gè)滿足條件的節(jié)點(diǎn),通過html基本知識(shí)我們可以知道元素對(duì)應(yīng)的id名是唯一的,像是其他的class等可以多次出現(xiàn),其中對(duì)應(yīng)的滿足條件的倘若還用一開始的方法便只能得到第一個(gè)節(jié)點(diǎn)的內(nèi)容,后面就不能得到,因此可以使用find_elements()。

3.節(jié)點(diǎn)交互

意思就是讓瀏覽器模擬執(zhí)行一些動(dòng)作,常用的有:輸入文字用send_keys(),清空文字用clear(),點(diǎn)擊用click()。放個(gè)小實(shí)例。

from selenium import webdriver
import time

browser = webdriver.Chrome()
browser.get('https://www.baidu.com')
input = browser.find_element_by_id('kw')
input.send_keys('Python')
time.sleep(1)		#等待時(shí)間設(shè)置為1秒,方便查看
input.clear()		#清空搜索框
input.send_keys('LOL')
button = browser.find_element_by_id('su')
button.click()		#模擬點(diǎn)擊

4.獲取節(jié)點(diǎn)信息

因?yàn)閟elenium的page_source屬性可以直接獲取網(wǎng)頁源碼,接著就可以直接使用解析庫(kù)(如正則表達(dá)式,Beautiful Soup等)直接提取信息,不過Selenium已經(jīng)直接提供了選擇節(jié)點(diǎn)的方法了,返回的是WebElement類型,它也有相關(guān)的方法提取節(jié)點(diǎn)信息,如文本,屬性等。這也是使用它進(jìn)行一點(diǎn)簡(jiǎn)單的爬蟲非常方便的原因,代碼十分簡(jiǎn)潔。

=提取屬性=

使用get_attribute()方法,但前提需要先選中節(jié)點(diǎn),同樣以百度首頁為實(shí)例,打印出百度logo的屬性。

from selenium import webdriver

browser = webdriver.Chrome()
browser.get('https://www.baidu.com')
input = browser.find_element_by_id('s_lg_img')
print(input)
print(input.get_attribute("class"))

'''打印結(jié)果
< selenium.webdriver.remote.webelement.WebElement (session="6013549f22f653cf081e0564da8315da", element="a924de49-358c-42e1-8c29-09bf0dd8d3c3") >
index-logo-src
'''

=獲取文本值=

每個(gè)WebElement節(jié)點(diǎn)都有text屬性,直接調(diào)用這個(gè)屬性就可以獲得節(jié)點(diǎn)內(nèi)的內(nèi)容,這相當(dāng)于Beautiful Soup中的get_text()方法。這里打開百度首頁,獲取搜索按鈕的百度一下文本。

from selenium import webdriver

browser = webdriver.Chrome()
browser.get('https://www.baidu.com')
input = browser.find_element_by_id('su')
print(input.text)

=獲取id、位置、標(biāo)簽名和大小=

id屬性獲取節(jié)點(diǎn)id
location屬性可以獲取該節(jié)點(diǎn)在頁面中的相對(duì)位置
tag_name屬性獲取標(biāo)簽名稱
size屬性獲取節(jié)點(diǎn)大小,就是寬高

5.延時(shí)等待

當(dāng)我們進(jìn)行網(wǎng)絡(luò)爬蟲時(shí),請(qǐng)求的東西或許不會(huì)第一時(shí)間出現(xiàn),此時(shí)就會(huì)拋出時(shí)間異常,因此我們需要加上延時(shí)等待避免程序中斷。這里面分為顯式等待和隱式等待,具體詳細(xì)教程參考鏈接: link.

6.異常處理

進(jìn)行爬蟲難免會(huì)遇到異常,如超時(shí),節(jié)點(diǎn)未找到等錯(cuò)誤,此時(shí)用try except語句捕獲異常,可以避免程序因此中斷。

關(guān)于Selenium其他的函數(shù)如對(duì)網(wǎng)頁節(jié)點(diǎn)進(jìn)行拖拽,切換標(biāo)簽頁,前進(jìn)與后退,選項(xiàng)卡管理以及對(duì)cookies相關(guān)的操作等不做詳細(xì)說明,上面的知識(shí)足以進(jìn)行簡(jiǎn)單的爬蟲了,像是各大網(wǎng)頁的文本值都可以很簡(jiǎn)單的抓取下來,可以做一點(diǎn)簡(jiǎn)單的數(shù)據(jù)分析。當(dāng)然這僅對(duì)初學(xué)者是這樣的,后期稍微深入會(huì)遇到需要這些函數(shù)的操作,對(duì)于小白這些就夠了。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • python
    +關(guān)注

    關(guān)注

    57

    文章

    4876

    瀏覽量

    90049
  • 異常中斷
    +關(guān)注

    關(guān)注

    0

    文章

    10

    瀏覽量

    1396
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    京東關(guān)鍵詞搜索商品列表的Python爬蟲實(shí)戰(zhàn)

    京東關(guān)鍵詞搜索商品列表 Python 爬蟲實(shí)戰(zhàn) 你想要實(shí)現(xiàn)京東關(guān)鍵詞搜索商品的爬蟲,我會(huì)從 合規(guī)聲明、環(huán)境準(zhǔn)備、頁面分析、代碼實(shí)現(xiàn)、反爬優(yōu)化 五個(gè)方面展開,幫助你完成實(shí)戰(zhàn)項(xiàng)目。 一、前置聲明(重要
    的頭像 發(fā)表于 01-04 10:16 ?752次閱讀

    沒有專利的opencv-python 版本

    4.8.x 及以上核心版(無專利、安裝簡(jiǎn)單、功能全); 若需擴(kuò)展功能,搭配 opencv-contrib-python-headless(無頭版),避免引入專利模塊; 無需擔(dān)心“專利繞過”,官方核心版本身無
    發(fā)表于 12-13 12:37

    Termux中調(diào)試圣誕樹Python代碼

    在Termux中調(diào)試Python代碼(以圣誕樹立例)非常簡(jiǎn)單,核心分為環(huán)境準(zhǔn)備、代碼編寫、運(yùn)行調(diào)試三個(gè)步驟,下面一步步教你操作: 一、環(huán)境準(zhǔn)備(首次使用需做) Termux默認(rèn)可能沒有Python
    發(fā)表于 12-09 09:02

    # 深度解析:爬蟲技術(shù)獲取淘寶商品詳情并封裝為API的全流程應(yīng)用

    需求。本文將深入探討如何借助爬蟲技術(shù)實(shí)現(xiàn)淘寶商品詳情的獲取,并將其高效封裝為API。 一、爬蟲技術(shù)核心原理與工具 1.1 爬蟲運(yùn)行機(jī)制 網(wǎng)絡(luò)爬蟲
    的頭像 發(fā)表于 11-17 09:29 ?351次閱讀

    Python 給 Amazon 做“全身 CT”——可量產(chǎn)、可擴(kuò)展的商品詳情爬蟲實(shí)戰(zhàn)

    一、技術(shù)選型:為什么選 Python 而不是 Java? 結(jié)論: “調(diào)研階段用 Python,上線后如果 QPS 爆表再考慮 Java 重構(gòu)。” 二、整體架構(gòu)速覽(3 分鐘看懂) 三、開發(fā)前準(zhǔn)備(5
    的頭像 發(fā)表于 10-21 16:59 ?520次閱讀
    用 <b class='flag-5'>Python</b> 給 Amazon 做“全身 CT”——可量產(chǎn)、可擴(kuò)展的商品詳情<b class='flag-5'>爬蟲</b>實(shí)戰(zhàn)

    從 0 到 1:用 PHP 爬蟲優(yōu)雅地拿下京東商品詳情

    PHP 語言 實(shí)現(xiàn)一個(gè) 可運(yùn)行的京東商品爬蟲 ,不僅能抓取商品標(biāo)題、價(jià)格、圖片、評(píng)價(jià)數(shù),還能應(yīng)對(duì)常見的反爬策略。全文附完整代碼, 復(fù)制粘貼即可運(yùn)行 。 一、為什么選擇 PHP 做爬蟲? 雖然 Python
    的頭像 發(fā)表于 09-23 16:42 ?858次閱讀
    從 0 到 1:用 PHP <b class='flag-5'>爬蟲</b>優(yōu)雅地拿下京東商品詳情

    Nginx限流與防爬蟲配置方案

    在互聯(lián)網(wǎng)業(yè)務(wù)快速發(fā)展的今天,網(wǎng)站面臨著各種流量沖擊和惡意爬蟲的威脅。作為運(yùn)維工程師,我們需要在保證正常用戶訪問的同時(shí),有效防范惡意流量和爬蟲攻擊。本文將深入探討基于Nginx的限流與防爬蟲解決方案,從原理到實(shí)踐,為大家提供一套完
    的頭像 發(fā)表于 09-09 15:52 ?911次閱讀

    termux調(diào)試python猜數(shù)字游戲

    用termux做一個(gè)猜數(shù)字游戲 下面是在Termux中創(chuàng)建猜數(shù)字游戲的步驟及完整實(shí)現(xiàn)方案,結(jié)合Python實(shí)現(xiàn)(最適配Termux環(huán)境): ? 一、環(huán)境準(zhǔn)備(Termux基礎(chǔ)配置) 1.
    發(fā)表于 08-29 17:15

    termux如何搭建python游戲

    termux如何搭建python游戲 Termux搭建Python游戲開發(fā)環(huán)境的完整指南 一、Termux基礎(chǔ)環(huán)境準(zhǔn)備 Termux是一款無需root即可在安卓設(shè)備上運(yùn)行的Linux終端
    發(fā)表于 08-29 07:06

    自動(dòng)化測(cè)試如何繞過Cloudflare驗(yàn)證碼?Python + Selenium 腳本實(shí)戰(zhàn)指南!

    01什么是Cloudflare驗(yàn)證碼Cloudflare提供網(wǎng)絡(luò)工具,并提供一套全面的安全功能,以保護(hù)網(wǎng)站免受各種在線威脅。Cloudflare驗(yàn)證碼是一種用于區(qū)分人類用戶和自動(dòng)化機(jī)器人的功能。它是
    的頭像 發(fā)表于 08-15 10:01 ?1332次閱讀
    自動(dòng)化測(cè)試如何繞過Cloudflare驗(yàn)證碼?<b class='flag-5'>Python</b> + <b class='flag-5'>Selenium</b> 腳本實(shí)戰(zhàn)指南!

    python app不能運(yùn)行怎么解決?

    ;python_agent[1241]: xmlrpc request method supervisor.stopProcess failed;python_agent[1241]: xmlrpc request method supervisor.stopProces
    發(fā)表于 08-06 06:27

    基礎(chǔ)篇3:掌握Python中的條件語句與循環(huán)

    不同的條件執(zhí)行不同的代碼塊。Python中的條件語句主要使用if、elif(else if的縮寫)和else關(guān)鍵字。 if語句 最簡(jiǎn)單的條件語句是if語句,它的工作方式如下: 復(fù)制代碼 if 條件表達(dá)式
    發(fā)表于 07-03 16:13

    python入門圣經(jīng)-高清電子書(建議下載)

    和Pygal 等強(qiáng)大的Python 庫(kù)和工具介紹,以及列表、字典、if 語句、類、文件與異常、代碼測(cè)試等內(nèi)容; 第二部分將理論付諸實(shí)踐,講解如何開發(fā)三個(gè)項(xiàng)目,包括簡(jiǎn)單Python 2D 游戲開發(fā)如何利用數(shù)據(jù)
    發(fā)表于 04-10 16:53

    零基礎(chǔ)入門:如何在樹莓派上編寫和運(yùn)行Python程序?

    在這篇文章中,我將為你簡(jiǎn)要介紹Python程序是什么、Python程序可以用來做什么,以及如何在RaspberryPi上編寫和運(yùn)行一個(gè)簡(jiǎn)單Python程序。什么是
    的頭像 發(fā)表于 03-25 09:27 ?2046次閱讀
    零基礎(chǔ)入門:如何在樹莓派上編寫和運(yùn)行<b class='flag-5'>Python</b>程序?

    爬蟲數(shù)據(jù)獲取實(shí)戰(zhàn)指南:從入門到高效采集

    爬蟲數(shù)據(jù)獲取實(shí)戰(zhàn)指南:從入門到高效采集 ? ? 在數(shù)字化浪潮中,數(shù)據(jù)已成為驅(qū)動(dòng)商業(yè)增長(zhǎng)的核心引擎。無論是市場(chǎng)趨勢(shì)洞察、競(jìng)品動(dòng)態(tài)追蹤,還是用戶行為分析,爬蟲技術(shù)都能助你快速捕獲目標(biāo)信息。然而,如何既
    的頭像 發(fā)表于 03-24 14:08 ?1581次閱讀