chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

寫網(wǎng)絡(luò)爬蟲程序的難度是怎么分等級(jí)的

Wildesbeast ? 來源:今日頭條 ? 作者:猿人學(xué) ? 2020-02-05 11:49 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

寫爬蟲,是一個(gè)非??简?yàn)綜合實(shí)力的活兒。有時(shí)候,你輕而易舉地就抓取到了想要的數(shù)據(jù);有時(shí)候,你費(fèi)盡心思卻毫無所獲。

好多Python爬蟲的入門教程都是一行代碼就把你騙上了“賊船”,等上了賊船才發(fā)現(xiàn),水好深~比如爬取一個(gè)網(wǎng)頁可以是很簡單的一行代碼:

r = requests.get('http://news.baidu.com')

非常的簡單,但它的作用也僅僅是爬取一個(gè)網(wǎng)頁,而一個(gè)有用的爬蟲遠(yuǎn)遠(yuǎn)不止于爬取一個(gè)網(wǎng)頁。

一個(gè)有用的爬蟲,只需兩個(gè)詞來衡量:

數(shù)量:能否抓全所有該類數(shù)據(jù)

效率:抓完所有數(shù)據(jù)需要多久一天還是一個(gè)月

但要做到這兩個(gè)詞,卻是要下很多功夫。自己下功夫是一方面,也很重要的是你要抓全的目標(biāo)網(wǎng)站給你出了多少難題。綜合起來,就寫一個(gè)爬蟲有多少難度。

網(wǎng)絡(luò)爬蟲難度一:只需爬取html網(wǎng)頁但要上規(guī)模

這里我們舉個(gè)新聞爬蟲的例子。大家都用過百度的新聞搜索吧,我就拿它的爬蟲來講講實(shí)現(xiàn)上的難度。

新聞網(wǎng)站基本上不設(shè)防,新聞內(nèi)容都在網(wǎng)頁的html代碼里了,抓全一個(gè)網(wǎng)頁基本上就是一行的事情。似乎聽上去很簡單,但對(duì)于一個(gè)搜索引擎級(jí)的爬蟲,就不那么簡單了,要把幾千幾萬家新聞網(wǎng)站的新聞都及時(shí)抓取到也不是一件容易的事情。

我們先看看新聞爬蟲的簡單流程圖:

從一些種子網(wǎng)頁開始,種子網(wǎng)頁往往是一些新聞網(wǎng)站的首頁,爬蟲抓取網(wǎng)頁,從中提取網(wǎng)站URL放到網(wǎng)址池再進(jìn)行抓取。這樣就從幾個(gè)網(wǎng)頁開始,不斷擴(kuò)展到其它網(wǎng)頁。爬蟲抓取的網(wǎng)頁也越來越多,提取出的新網(wǎng)網(wǎng)址也會(huì)成幾何級(jí)數(shù)增長。

如何能在最短時(shí)間抓取更多網(wǎng)址?

這就是其中一個(gè)難度,這不是目標(biāo)網(wǎng)址帶來的,而是對(duì)我們自身自愿的考驗(yàn):

我們的帶寬夠嗎

我們的服務(wù)器夠嗎,單臺(tái)不夠就要分布式

如何能及時(shí)抓取到最新的新聞?

這是效率之外的另一個(gè)難度,如何保證及時(shí)性?幾千家新聞網(wǎng)站,時(shí)刻都在發(fā)布最新新聞,爬蟲在織網(wǎng)式抓取“舊”新聞的同時(shí),如何兼顧獲取“新”新聞呢?

如何存儲(chǔ)抓取到的海量新聞?

爬蟲織網(wǎng)式的爬取,會(huì)把每個(gè)網(wǎng)站幾年前幾十年前的新聞網(wǎng)頁都給翻出來,從而獲得海量的網(wǎng)頁需要存儲(chǔ)。就是存儲(chǔ)上的難度。

如何清理提取網(wǎng)內(nèi)容?

從新聞網(wǎng)頁的html里面快速、準(zhǔn)確提取想要的信息數(shù)據(jù),比如標(biāo)題、發(fā)布時(shí)間、正文內(nèi)容等,這又帶來內(nèi)容提取上的難度。

網(wǎng)絡(luò)爬蟲難度二:需要登錄才能抓到想要的數(shù)據(jù)

人是貪婪的,想要的數(shù)據(jù)無窮盡,但是很多數(shù)據(jù)不是你輕易就可以獲得的。有一大類數(shù)據(jù)就是需要賬戶登錄后才能看到,也就是說,爬蟲請(qǐng)求時(shí)必須是登錄狀態(tài)才能抓取數(shù)據(jù)。

如何獲取登錄狀態(tài)?

老猿前面已經(jīng)說過了,http協(xié)議的性質(zhì)決定了登錄狀態(tài)就是一些cookies,那么如何獲得登錄狀態(tài)就是一個(gè)非常有難度的問題。

有些網(wǎng)站登錄過程很簡單,把賬戶、密碼發(fā)給服務(wù)器,服務(wù)器驗(yàn)證通過返回表示已登錄的cookies。這樣的網(wǎng)站,比較容易實(shí)現(xiàn)自動(dòng)登錄,爬蟲運(yùn)行過程全程無需人工干預(yù),你就有更多時(shí)間喝茶、聊天、上猿人學(xué)看python。

如何處理驗(yàn)證碼?

然而,網(wǎng)站們既然要求你登錄了,他們就不會(huì)這么輕易放過你,要做的更絕才能讓小猿們善罷甘休,那就是上驗(yàn)證碼!

沒錯(cuò),就是變態(tài)的驗(yàn)證碼。

有的運(yùn)用社會(huì)工程,進(jìn)行人工識(shí)別驗(yàn)證碼;也有,通過圖像處理技術(shù),尤其如今火熱的深度學(xué)習(xí)、人工智能的技術(shù),來自動(dòng)識(shí)別驗(yàn)證碼。

那么,當(dāng)你寫爬蟲時(shí)遇到驗(yàn)證碼該怎么辦?

網(wǎng)絡(luò)爬蟲難度三:異步加載甚至JavaScript解密

前面的兩個(gè)難度,都是靠我們研究數(shù)據(jù)加載過程,然后用Python代碼可以重現(xiàn)出來,進(jìn)行抓取的。

而遇到達(dá)第三個(gè)難度時(shí),研究數(shù)據(jù)加載過程會(huì)讓你十分痛苦、近乎崩潰。異步加載流程和服務(wù)器來來回回好多次,最后得到的數(shù)據(jù)還要通過JavaScript解密才能看到,這都是壓垮小猿們的最后一根稻草。

有沒有終極大招可以破解呢?

網(wǎng)絡(luò)爬蟲難度四:APP的抓取

APP連包都抓不到

抓包是寫爬蟲組裝請(qǐng)求數(shù)據(jù)的基礎(chǔ)條件,對(duì)APP抓包的繁復(fù)度遠(yuǎn)超網(wǎng)站,APP對(duì)代理抓包的檢測(cè),對(duì)網(wǎng)絡(luò)請(qǐng)求庫的混淆,使用socket通信等阻擋了相當(dāng)部分爬蟲選手。

請(qǐng)求Token參數(shù)的加密

APP請(qǐng)求參數(shù)的組裝是一個(gè)黑盒,不一窺參數(shù)的組裝流程,請(qǐng)求不到數(shù)據(jù);APP repsonse回來的數(shù)據(jù)可能是二進(jìn)制或編碼過,不知道如何解碼還原,抓下來數(shù)據(jù)也只能望洋興嘆。

要能正確抓取APP數(shù)據(jù)就需要具備網(wǎng)絡(luò)安全行業(yè)的初中級(jí)知識(shí)。

總結(jié)了一下這爬蟲的一些難度,明年應(yīng)該會(huì)結(jié)合一些實(shí)際示例來講解如何破解這些不同程度的難題。

聲明:本文內(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)投訴
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4922

    瀏覽量

    72237
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4848

    瀏覽量

    88953
  • 爬蟲
    +關(guān)注

    關(guān)注

    0

    文章

    85

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    網(wǎng)線分等級(jí)嗎?常見的網(wǎng)線等級(jí)有哪些

    網(wǎng)線確實(shí)存在等級(jí)劃分,主要依據(jù)其傳輸性能、適用場(chǎng)景和標(biāo)準(zhǔn)規(guī)范進(jìn)行分類。以下是常見的網(wǎng)線等級(jí)及特點(diǎn): 一、按傳輸速率分類 Cat5(五類線) 傳輸頻率:100MHz 最大速率:100Mbps(百兆
    的頭像 發(fā)表于 10-10 10:52 ?196次閱讀

    從 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 ?385次閱讀
    從 0 到 1:用 PHP <b class='flag-5'>爬蟲</b>優(yōu)雅地拿下京東商品詳情

    電能質(zhì)量在線監(jiān)測(cè)裝置的精度等級(jí)和準(zhǔn)確度的關(guān)系是否受測(cè)量參數(shù)的影響?

    ,導(dǎo)致同一裝置對(duì)不同參數(shù)的 “精度等級(jí)標(biāo)稱” 與 “實(shí)際準(zhǔn)確度表現(xiàn)” 的匹配關(guān)系完全不同 —— 部分參數(shù)的準(zhǔn)確度易符合其精度等級(jí),部分參數(shù)則可能因測(cè)量難度高而偏離精度等級(jí)。 一、核心前
    的頭像 發(fā)表于 09-12 10:02 ?349次閱讀
    電能質(zhì)量在線監(jiān)測(cè)裝置的精度<b class='flag-5'>等級(jí)</b>和準(zhǔn)確度的關(guān)系是否受測(cè)量參數(shù)的影響?

    Nginx限流與防爬蟲配置方案

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

    設(shè)置RDP等級(jí)為2的同時(shí),有什么辦法可以確保后續(xù)還能夠燒錄程序?

    請(qǐng)問有在將RDP等級(jí)設(shè)置為2的前提下,確保后續(xù)還能夠燒錄程序的辦法嗎
    發(fā)表于 07-10 06:12

    IP防護(hù)等級(jí)說明

    IP防護(hù)等級(jí)說明
    發(fā)表于 06-24 16:55 ?0次下載

    流量傳感器在半導(dǎo)體芯片測(cè)試的分選機(jī)中應(yīng)用

    Test):對(duì)封裝完成后的每顆芯片進(jìn)行功能和電參數(shù)測(cè)試,分出芯片好壞或分等級(jí)。國內(nèi)分選機(jī)的重任工作還是用于芯片成品測(cè)試,測(cè)試平臺(tái)主要包括測(cè)試機(jī)、分選機(jī)、測(cè)試座等設(shè)備和材料,在芯片成片環(huán)節(jié)主要流程和晶圓測(cè)試類似: ? 傳送:分選機(jī)將
    的頭像 發(fā)表于 04-23 09:13 ?545次閱讀
    流量傳感器在半導(dǎo)體芯片測(cè)試的分選機(jī)中應(yīng)用

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

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

    難度PCB不再難!捷多邦揭秘PCB制作難度層級(jí)

    在電子行業(yè)中,PCB(印刷電路板)是不可或缺的核心組成部分。從簡單的電子玩具到復(fù)雜的航天設(shè)備,PCB的制作難度各異。今天,我們就來揭秘PCB制作的難度排行榜,看看哪些類型的PCB制作起來最為挑戰(zhàn)
    的頭像 發(fā)表于 03-05 17:04 ?973次閱讀

    IP地址數(shù)據(jù)信息和爬蟲攔截的關(guān)聯(lián)

    IP地址數(shù)據(jù)信息和爬蟲攔截的關(guān)聯(lián)主要涉及到兩方面的內(nèi)容,也就是數(shù)據(jù)信息和爬蟲。IP 地址數(shù)據(jù)信息的內(nèi)容豐富,包括所屬地域、所屬網(wǎng)絡(luò)運(yùn)營商、訪問時(shí)間序列、訪問頻率等。 從IP地址信息中可以窺見
    的頭像 發(fā)表于 12-23 10:13 ?554次閱讀

    程序和進(jìn)程的區(qū)別

    比如: 開發(fā)的代碼我們稱為程序,那么將開發(fā)的代碼運(yùn)行起來。我們稱為進(jìn)程。
    的頭像 發(fā)表于 11-25 16:03 ?1612次閱讀
    <b class='flag-5'>程序</b>和進(jìn)程的區(qū)別

    華為聯(lián)合發(fā)布《自智網(wǎng)絡(luò)等級(jí)測(cè)評(píng)白皮書》

    近日,由TM Forum主辦的Innovate Asia峰會(huì)在泰國曼谷舉行。在峰會(huì)期間,TM Forum和華為聯(lián)合產(chǎn)業(yè)伙伴共同發(fā)布了《自智網(wǎng)絡(luò)等級(jí)測(cè)評(píng)白皮書》,并為首批通過自智網(wǎng)絡(luò)等級(jí)
    的頭像 發(fā)表于 11-09 15:59 ?1592次閱讀

    觸摸屏驅(qū)動(dòng)板無法燒程序的相關(guān)原因

    每次聽到別人說是什么原因?qū)е掠|摸屏驅(qū)動(dòng)板無法燒程序,就很想去討論一下。今天就跟大家聊聊到底是什么原因?qū)е碌摹?/div>
    的頭像 發(fā)表于 10-21 11:19 ?1099次閱讀