日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

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

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

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

掃碼添加小助手

加入工程師交流群

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

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

準備工作:

使用它肯定先要安裝它,對于Selenium的安裝推薦使用pip,十分方便。因為我使用的是谷歌瀏覽器,使用前需要先配置相應的ChromeDriver,在此放出對應谷歌瀏覽器對應的80版本的ChromeDriver。地址 :點擊下載提取碼:sz2s
至于如何去安裝配置,網(wǎng)絡上有很多教程,在此不做贅述。

簡要功能:

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

1.訪問頁面

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

from selenium import webdriver

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

2.查找節(jié)點

selenium可以驅動瀏覽器完成各種操作,但進行模擬點擊,填寫表單時,我們總要知道這些輸入框,點擊按鈕在哪里,所以需要獲取相對的節(jié)點??偣灿衅渲袑ふ夜?jié)點的方法,在此給出一個非常全面的學習查找節(jié)點的教程。

=單個節(jié)點=
下面以百度首頁為例。通過查找源碼,我們可以發(fā)現(xiàn)對應搜索文本框的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)容

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

圖片

=多個節(jié)點=

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

3.節(jié)點交互

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

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)		#等待時間設置為1秒,方便查看
input.clear()		#清空搜索框
input.send_keys('LOL')
button = browser.find_element_by_id('su')
button.click()		#模擬點擊

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

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

=提取屬性=

使用get_attribute()方法,但前提需要先選中節(jié)點,同樣以百度首頁為實例,打印出百度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"))

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

=獲取文本值=

每個WebElement節(jié)點都有text屬性,直接調(diào)用這個屬性就可以獲得節(jié)點內(nèi)的內(nèi)容,這相當于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、位置、標簽名和大小=

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

5.延時等待

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

6.異常處理

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

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

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

    關注

    58

    文章

    4889

    瀏覽量

    90327
  • 異常中斷
    +關注

    關注

    0

    文章

    10

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    AI算法核心知識清單(深度實戰(zhàn)版4)

    Scrapy+Selenium)、公開數(shù)據(jù)集下載(如ImageNet、COCO)文本數(shù)據(jù):網(wǎng)頁爬蟲(如BeautifulSoup爬取新聞、博客)、社交媒體API(如Twi
    的頭像 發(fā)表于 04-30 09:22 ?196次閱讀
    AI算法核心知識清單(深度實戰(zhàn)版4)

    Python全棧一課通(470集)(12.96 GB)-網(wǎng)盤資源下載

    爬蟲是對網(wǎng)絡通信與反爬策略的實戰(zhàn);自動化則是對操作系統(tǒng)底層交互的掌控。這些技能看似散落,實則都扎根于 Python 的底層生態(tài)。這種“全?!蹦芰嫿艘粡埢ハ嘟豢椀募寄芫W(wǎng),無論技術風口如何轉變,你都能
    發(fā)表于 04-19 16:30

    使用Python/MyHDL創(chuàng)建自定義FPGA IP

    使用 Python/MyHDL 創(chuàng)建自定義 FPGA IP,與 Vivado 集成,并通過 PYNQ 進行控制——實現(xiàn)軟件上的簡單硬件設計。
    的頭像 發(fā)表于 04-09 09:53 ?284次閱讀
    使用<b class='flag-5'>Python</b>/MyHDL創(chuàng)建自定義FPGA IP

    [VirtualLab] 使用Python運行VirtualLab Fusion光學仿真

    Fusion的簡單方法。在本示例中,我們將演示如何使用Python腳本運行光學仿真,以向用戶簡要概述這種跨平臺的仿真能力。 用例概覽 文件路徑 用戶可以在樣本文件的文件夾中找到所有文件。包含這些文件
    發(fā)表于 03-31 09:39

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

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

    沒有專利的opencv-python 版本

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

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

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

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

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

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

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

    Nginx限流與防爬蟲配置方案

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

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

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

    termux如何搭建python游戲

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

    自動化測試如何繞過Cloudflare驗證碼?Python + Selenium 腳本實戰(zhàn)指南!

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

    python app不能運行怎么解決?

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

    基于FPGA搭建神經(jīng)網(wǎng)絡的步驟解析

    本文的目的是在一個神經(jīng)網(wǎng)絡已經(jīng)通過python或者MATLAB訓練好的神經(jīng)網(wǎng)絡模型,將訓練好的模型的權重和偏置文件以TXT文件格式導出,然后通過python程序將txt文件轉化為coe
    的頭像 發(fā)表于 06-03 15:51 ?1531次閱讀
    基于FPGA搭建神經(jīng)<b class='flag-5'>網(wǎng)絡</b>的步驟解析
    刚察县| 富裕县| 河东区| 南昌县| 衡南县| 诸城市| 乐至县| 阳曲县| 黄平县| 措勤县| 龙江县| 新野县| 巩义市| 辰溪县| 偏关县| 大悟县| 长宁区| 北票市| 枝江市| 和林格尔县| 夏津县| 玉门市| 南安市| 临湘市| 甘肃省| 沙洋县| 杨浦区| 聊城市| 会昌县| 兖州市| 井研县| 永宁县| 隆安县| 沭阳县| 商城县| 太康县| 星座| 红安县| 铜鼓县| 泰宁县| 南澳县|