爬取百度貼吧實戰,python教你如何獲取

隨遇啊發表於2020-12-07

1,目標:

爬取貼吧每一貼,樓主圖,並儲存。

由於圖片大多是樓主發的,如果全部查詢會浪費很多時間。

2,分析

我選擇爬取的貼吧為圖吧,你們可以選擇自己想要爬取的貼吧。

2.1,獲取頁面

我們將爬取頁面的程式碼寫成一個get_html()方法,給他傳入url引數

程式碼如圖:

在這裡插入圖片描述

獲取正常,沒問題。

我們用chrome的開發者模式來分析每個貼的連線,用定位定位一個帖子,這樣方便我們快速的去查詢我們想要的資訊。

如圖:

在這裡插入圖片描述

2.2利用正規表示式找出我們想要的連線

通過查詢,我們發現每個貼都是在class=“col2_right j_threalist_li/_right”下

我們可以讓他成為一個標誌位,通過它繼續往下找,他有兩個類名,我們選擇後者即可。

<div.?j_threadlist_li_right.?>.?<a.?href="(.?)".?>(.*?)

返回的是一個陣列,為了好看我們以字典的方式返回,用yield我們可以理解為返回值,在python基礎裡會講,我們將獲取的頁面作為引數傳進去,實現get_url方法。

如圖:
在這裡插入圖片描述

我們來列印一下,看一下獲取的是什麼?

結果如圖:

在這裡插入圖片描述

很明顯,我們需要來拼接一下,獲取完整的url,我們點選一個進入,可以發現,url是這樣的:https://tieba.baidu.com/p/5768252315,我們得到了後半部分,那就容易了,只需要拼接一下,得到的結果就變成了:

在這裡插入圖片描述

得到連結後,我們需要再次傳送請求,獲取到每個貼的內容,即呼叫我們上面寫好的get_html()方法即可。

2.3找到每個帖子樓主發的圖片連結

同樣的方式,開啟開發者模式,找的圖片,找出標誌位,寫出正則,這裡就不詳細說了,正則為:

實現get_img_url()方法:

在這裡插入圖片描述

結果圖為:

在這裡插入圖片描述

2.4獲取到圖片地址後,自然是要下載下來實現write_to_file()方法

下載圖片,在上篇文章上已經有例項,

連線:python第二大神器requests

這裡直接上程式碼圖:

在這裡插入圖片描述

裡面的正則是用來作為圖片名字的,time.sleep(2)是為了爬取慢點

太快會無響應或者報錯。

下面我們試一下效果:

在這裡插入圖片描述

我們來修改一下,來爬取第一頁貼種的所有貼,獲取樓主貼的總頁數

和上面同樣的方式找到總頁數,並寫出獲取總頁數的正則:

實現get_ye方法,同時點選只看樓主,url會多出see_lz=1

如圖:
在這裡插入圖片描述

2.5由於有些貼吧的貼子很多,我們就選擇獲取前十頁內容,當然你也可以寫個方法換取所有頁

這裡就不例項了,在貼吧裡點選下一頁我們發現url多出pn=50,由此我們知道50為偏移量,即一頁有50個帖子pn=n 是n+1到n+50帖子

2.6整合一下程式碼,我們用main()方法來呼叫上面的方法。

如圖:
在這裡插入圖片描述
在這裡插入圖片描述
在這裡插入圖片描述
推薦一下我建的python學習交流扣扣qun:850973621,群裡有免費的視訊教程,開發工具、
電子書籍、專案原始碼分享。一起交流學習,一起進步!

作者:小新你蠟筆呢
連結:https://www.jianshu.com/p/27c534394890
來源:簡書
著作權歸作者所有。商業轉載請聯絡作者獲得授權,非商業轉載請註明出處。

相關文章