Python3爬蟲中關(guān)于Ajax分析方法的總結(jié)
這里還以前面的微博為例,我們知道拖動(dòng)刷新的內(nèi)容由Ajax加載,而且頁(yè)面的URL沒(méi)有變化,那么應(yīng)該到哪里去查看這些Ajax請(qǐng)求呢?
1. 查看請(qǐng)求
這里還需要借助瀏覽器的開發(fā)者工具,下面以Chrome瀏覽器為例來(lái)介紹。
首先,用Chrome瀏覽器打開微博的鏈接https://m.weibo.cn/u/2830678474,隨后在頁(yè)面中點(diǎn)擊鼠標(biāo)右鍵,從彈出的快捷菜單中選擇“檢查”選項(xiàng),此時(shí)便會(huì)彈出開發(fā)者工具,如圖6-2所示:

此時(shí)在Elements選項(xiàng)卡中便會(huì)觀察到網(wǎng)頁(yè)的源代碼,右側(cè)便是節(jié)點(diǎn)的樣式。
不過(guò)這不是我們想要尋找的內(nèi)容。切換到Network選項(xiàng)卡,隨后重新刷新頁(yè)面,可以發(fā)現(xiàn)這里出現(xiàn)了非常多的條目,如圖6-3所示。

前面也提到過(guò),這里其實(shí)就是在頁(yè)面加載過(guò)程中瀏覽器與服務(wù)器之間發(fā)送請(qǐng)求和接收響應(yīng)的所有記錄。
Ajax其實(shí)有其特殊的請(qǐng)求類型,它叫作xhr。在圖6-3中,我們可以發(fā)現(xiàn)一個(gè)名稱以getIndex開頭的請(qǐng)求,其Type為xhr,這就是一個(gè)Ajax請(qǐng)求。用鼠標(biāo)點(diǎn)擊這個(gè)請(qǐng)求,可以查看這個(gè)請(qǐng)求的詳細(xì)信息,如圖6-4所示。

在右側(cè)可以觀察到其Request Headers、URL和Response Headers等信息。其中Request Headers中有一個(gè)信息為X-Requested-With:XMLHttpRequest,這就標(biāo)記了此請(qǐng)求是Ajax請(qǐng)求,如圖6-5所示。

隨后點(diǎn)擊一下Preview,即可看到響應(yīng)的內(nèi)容,它是JSON格式的。這里Chrome為我們自動(dòng)做了解析,點(diǎn)擊箭頭即可展開和收起相應(yīng)內(nèi)容,如圖6-6所示。

觀察可以發(fā)現(xiàn),這里的返回結(jié)果是我的個(gè)人信息,如昵稱、簡(jiǎn)介、頭像等,這也是用來(lái)渲染個(gè)人主頁(yè)所使用的數(shù)據(jù)。JavaScript接收到這些數(shù)據(jù)之后,再執(zhí)行相應(yīng)的渲染方法,整個(gè)頁(yè)面就渲染出來(lái)了。
另外,也可以切換到Response選項(xiàng)卡,從中觀察到真實(shí)的返回?cái)?shù)據(jù),如圖6-7所示。

接下來(lái),切回到第一個(gè)請(qǐng)求,觀察一下它的Response是什么,如圖6-8所示。

這是最原始的鏈接https://m.weibo.cn/u/2830678474返回的結(jié)果,其代碼只有不到50行,結(jié)構(gòu)也非常簡(jiǎn)單,只是執(zhí)行了一些JavaScript。
所以說(shuō),我們看到的微博頁(yè)面的真實(shí)數(shù)據(jù)并不是最原始的頁(yè)面返回的,而是后來(lái)執(zhí)行JavaScript后再次向后臺(tái)發(fā)送了Ajax請(qǐng)求,瀏覽器拿到數(shù)據(jù)后再進(jìn)一步渲染出來(lái)的。
2. 過(guò)濾請(qǐng)求
接下來(lái),再利用Chrome開發(fā)者工具的篩選功能篩選出所有的Ajax請(qǐng)求。在請(qǐng)求的上方有一層篩選欄,直接點(diǎn)擊XHR,此時(shí)在下方顯示的所有請(qǐng)求便都是Ajax請(qǐng)求了,如圖6-9所示。

接下來(lái),不斷滑動(dòng)頁(yè)面,可以看到頁(yè)面底部有一條條新的微博被刷出,而開發(fā)者工具下方也一個(gè)個(gè)地出現(xiàn)Ajax請(qǐng)求,這樣我們就可以捕獲到所有的Ajax請(qǐng)求了。
隨意點(diǎn)開一個(gè)條目,都可以清楚地看到其Request URL、Request Headers、Response Headers、Response Body等內(nèi)容,此時(shí)想要模擬請(qǐng)求和提取就非常簡(jiǎn)單了。
圖6-10所示的內(nèi)容便是我的某一頁(yè)微博的列表信息。

到現(xiàn)在為止,我們已經(jīng)可以分析出來(lái)Ajax請(qǐng)求的一些詳細(xì)信息了,接下來(lái)只需要用程序模擬這些Ajax請(qǐng)求,就可以輕松提取我們所需要的信息了。
在下一節(jié)中,我們用Python實(shí)現(xiàn)Ajax請(qǐng)求的模擬,從而實(shí)現(xiàn)數(shù)據(jù)的抓取。
以上就是Python3爬蟲中關(guān)于Ajax分析方法的總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于Python3爬蟲里Ajax分析方法的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python筆記(1) 關(guān)于我們應(yīng)不應(yīng)該繼續(xù)學(xué)習(xí)python
關(guān)于Python,如果你要學(xué)習(xí),建議大家查看一下網(wǎng)站:因?yàn)楸救艘彩莿倓倹Q定收集點(diǎn)零碎時(shí)間來(lái)學(xué)習(xí)下它,推薦可能并不是最好的2012-10-10
Pandas實(shí)現(xiàn)一列數(shù)據(jù)分隔為兩列
這篇文章主要介紹了Pandas實(shí)現(xiàn)一列數(shù)據(jù)分隔為兩列,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-05-05
Python爬取豆瓣數(shù)據(jù)實(shí)現(xiàn)過(guò)程解析
這篇文章主要介紹了Python爬取豆瓣數(shù)據(jù)實(shí)現(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10
python+logging+yaml實(shí)現(xiàn)日志分割
這篇文章主要為大家詳細(xì)介紹了python+logging+yaml實(shí)現(xiàn)日志分割,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07
Python openpyxl讀取單元格字體顏色過(guò)程解析
這篇文章主要介紹了Python openpyxl讀取單元格字體顏色過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09
python標(biāo)準(zhǔn)庫(kù)ElementTree處理xml
這篇文章主要為大家介紹了python標(biāo)準(zhǔn)庫(kù)ElementTree處理xml的方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
Python Sleep休眠函數(shù)使用簡(jiǎn)單實(shí)例
這篇文章主要介紹了Python Sleep休眠函數(shù)使用簡(jiǎn)單實(shí)例,本文直接給出兩個(gè)實(shí)現(xiàn)例子,需要的朋友可以參考下2015-02-02
Python 實(shí)現(xiàn)反轉(zhuǎn)整數(shù)的案例(很容易懂的那種)
這篇文章主要介紹了Python 實(shí)現(xiàn)反轉(zhuǎn)整數(shù)的案例(很容易懂的那種),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03
pandas將numpy數(shù)組寫入到csv的實(shí)例
今天小編就為大家分享一篇pandas將numpy數(shù)組寫入到csv的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07

