欧美性猛交xxxx免费看_牛牛在线视频国产免费_天堂草原电视剧在线观看免费_国产粉嫩高清在线观看_国产欧美日本亚洲精品一5区

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 ? 來(lái)源:今日頭條 ? 作者:猿人學(xué) ? 2020-02-05 11:49 ? 次閱讀

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

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

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

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

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

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

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

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

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

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

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

我們先看看新聞爬蟲的簡(jiǎn)單流程圖:

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

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

這就是其中一個(gè)難度,這不是目標(biāo)網(wǎng)址帶來(lái)的,而是對(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)頁(yè)都給翻出來(lái),從而獲得海量的網(wǎng)頁(yè)需要存儲(chǔ)。就是存儲(chǔ)上的難度。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

有沒(méi)有終極大招可以破解呢?

網(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)求庫(kù)的混淆,使用socket通信等阻擋了相當(dāng)部分爬蟲選手。

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

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

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

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

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

    關(guān)注

    30

    文章

    4841

    瀏覽量

    69147
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4811

    瀏覽量

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

    關(guān)注

    0

    文章

    82

    瀏覽量

    7024
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    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)營(yíng)商、訪問(wèn)時(shí)間序列、訪問(wèn)頻率等。 從IP地址信息中可以窺見(jiàn)
    的頭像 發(fā)表于 12-23 10:13 ?108次閱讀

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

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

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

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

    全球視野下的海外爬蟲IP:趨勢(shì)、機(jī)遇與風(fēng)險(xiǎn)

    在全球視野下,海外爬蟲IP的使用呈現(xiàn)出一系列趨勢(shì),同時(shí)也伴隨著機(jī)遇與風(fēng)險(xiǎn)。
    的頭像 發(fā)表于 10-15 07:54 ?279次閱讀

    海外爬蟲IP的合法邊界:合規(guī)性探討與實(shí)踐

    海外爬蟲IP的合法邊界主要涉及合規(guī)性探討與實(shí)踐。
    的頭像 發(fā)表于 10-12 07:56 ?282次閱讀

    如何利用海外爬蟲IP進(jìn)行數(shù)據(jù)抓取

    利用海外爬蟲IP進(jìn)行數(shù)據(jù)抓取需要綜合考慮多個(gè)方面。
    的頭像 發(fā)表于 10-12 07:54 ?264次閱讀

    詳細(xì)解讀爬蟲多開(kāi)代理IP的用途,以及如何配置!

    爬蟲多開(kāi)代理IP是一種在爬蟲開(kāi)發(fā)中常用的技術(shù)策略,主要用于提高數(shù)據(jù)采集效率、避免IP被封禁以及獲取地域特定的數(shù)據(jù)。
    的頭像 發(fā)表于 09-14 07:55 ?565次閱讀

    瀚海微SD NAND存儲(chǔ)功能描述(23)速度等級(jí)測(cè)量條件和要求

    應(yīng)用程序提供余量。 注:2級(jí)至6級(jí)在默認(rèn)速度模式下以20MHz測(cè)量,10級(jí)在高速模式下以40MHz測(cè)量 注意事項(xiàng):最低性能是在SD總線使用率達(dá)到100%時(shí)(訪問(wèn)時(shí)不假設(shè)有空閑時(shí)間),因此不定期卡會(huì)降低性能。 各轉(zhuǎn)速等級(jí)性能參數(shù)
    的頭像 發(fā)表于 09-05 10:24 ?391次閱讀

    浪涌保護(hù)器怎么區(qū)分等級(jí)

    浪涌保護(hù)器(Surge Protection Device,簡(jiǎn)稱SPD)是一種用于保護(hù)電氣設(shè)備免受浪涌電流(Surge)損害的裝置。浪涌電流是由于電氣系統(tǒng)中的瞬態(tài)過(guò)電壓或過(guò)電流引起的,可能對(duì)設(shè)備造成嚴(yán)重?fù)p害。浪涌保護(hù)器通過(guò)限制浪涌電流的幅度和持續(xù)時(shí)間,從而保護(hù)電氣設(shè)備免受損害。 一、浪涌保護(hù)器的分類 按保護(hù)對(duì)象分類 浪涌保護(hù)器可以根據(jù)保護(hù)對(duì)象的不同分為以下幾類: (1)電源浪涌保護(hù)器:用于保護(hù)電源系統(tǒng)的設(shè)備,如變壓器、發(fā)電機(jī)、電動(dòng)機(jī)等。 (2)信號(hào)
    的頭像 發(fā)表于 07-13 14:48 ?1100次閱讀

    網(wǎng)絡(luò)爬蟲,Python和數(shù)據(jù)分析

    電子發(fā)燒友網(wǎng)站提供《網(wǎng)絡(luò)爬蟲,Python和數(shù)據(jù)分析.pdf》資料免費(fèi)下載
    發(fā)表于 07-13 09:27 ?2次下載

    數(shù)據(jù)采集方法有哪些?工具有哪些?

    數(shù)據(jù)采集是數(shù)據(jù)分析和數(shù)據(jù)科學(xué)的基礎(chǔ),它涉及到從各種來(lái)源收集、整理和存儲(chǔ)數(shù)據(jù)的過(guò)程。以下是一些常見(jiàn)的數(shù)據(jù)采集方法和工具,以及它們的特點(diǎn)和應(yīng)用場(chǎng)景。 網(wǎng)絡(luò)爬蟲 網(wǎng)絡(luò)爬蟲是一種自動(dòng)化的
    的頭像 發(fā)表于 07-01 15:35 ?1663次閱讀

    阿里云內(nèi)部全面推行AI代碼

    阿里云正在內(nèi)部全面推行 AI 編程,使用通義靈碼輔助程序代碼、讀代碼、查 BUG、優(yōu)化代碼等。
    的頭像 發(fā)表于 04-07 09:22 ?609次閱讀

    臺(tái)灣電價(jià)全面調(diào)整,大戶調(diào)漲幅度最大,民生用電不分等級(jí)全面上調(diào)

    臺(tái)灣電力公司目前需要通過(guò)提升電價(jià)來(lái)彌補(bǔ)資金虧空,以免陷入資不抵債的困境。從四月開(kāi)始,民生與產(chǎn)業(yè)用電價(jià)格上調(diào)的概率較大。根據(jù)中國(guó)臺(tái)灣經(jīng)濟(jì)部門的初步計(jì)劃,為了使低功率用戶的電價(jià)恢復(fù)至合理水平
    的頭像 發(fā)表于 03-10 12:22 ?1161次閱讀

    濕敏元器件存儲(chǔ)及使用規(guī)范

    到6級(jí)不等,每個(gè)級(jí)別代表不同的濕敏程度。較低的級(jí)別表示材料或產(chǎn)品對(duì)濕度變化更加敏感,可能需要更為嚴(yán)格的控制和保護(hù)措施,以避免損壞或性能下降。 器件容易受潮導(dǎo)致分層及部分損壞,為了避免器件損壞, 對(duì)不同材質(zhì)器件濕敏進(jìn)行要求,因此而劃分等級(jí)如下圖: 器件拆封
    的頭像 發(fā)表于 03-10 11:18 ?6475次閱讀
    濕敏元器件存儲(chǔ)及使用規(guī)范

    全球新聞網(wǎng)封鎖OpenAI和谷歌AI爬蟲

    分析結(jié)果顯示,至2023年底,超半數(shù)(57%)的傳統(tǒng)印刷媒體如《紐約時(shí)報(bào)》等已關(guān)閉OpenAI爬蟲,反之電視廣播以及數(shù)字原生媒體相應(yīng)地分別為48%和31%。而對(duì)于谷歌人工智能爬蟲,32%的印刷媒體采取相同措施,電視廣播和數(shù)字原生媒體的比率分別為19%和17%。
    的頭像 發(fā)表于 02-27 15:31 ?947次閱讀