用Python腳本自動(dòng)爬取Bilibili小視頻窝爪,你學(xué)會(huì)了嗎洒放?

B站在小視頻功能處提供了 API 接口,今天的任務(wù)爬取Bilibili視頻~

B 站視頻網(wǎng)址:https://vc.bilibili.com/p/eden/rank#/?tab=全部

image.png

此次爬取視頻蛉鹿,我們爬取前100個(gè)~

我們做好前期準(zhǔn)備~

1:Chrome 瀏覽器 (能使用開發(fā)者模式的瀏覽器都行)
2:Vim (編輯器任選,老實(shí)人比較喜歡Vim界面往湿,所以才用這個(gè)啦)
3:Python3 開發(fā)環(huán)境
4:Kali Linux (其實(shí)隨便一個(gè)操作系統(tǒng)都行啦)
5:API 尋找 && 提取

我們通過 F12 打開開發(fā)者模式妖异,然后在 Networking -> Name 字段下找到這個(gè)鏈接:

http://api.vc.bilibili.com/board/v1/ranking/top?page_size=10&next_offset=&tag=%E4%BB%8A%E6%97%A5%E7%83%AD%E9%97%A8&platform=pc

我們查看一下 Headers 屬性
image.png

我們可以看到Request URL這個(gè)屬性值,我們向下滑動(dòng)加載視頻的過程中领追,發(fā)現(xiàn)只有這段url是不變的他膳。

http://api.vc.bilibili.com/board/v1/ranking/top?

next_offset 會(huì)一直變化,我們可以猜測绒窑,這個(gè)可能就是獲取下一個(gè)視頻序號(hào)棕孙,我們只需要把這部分參數(shù)取出來,把 next_offset 寫成變量值些膨,用 JSON 的格式返回到目標(biāo)網(wǎng)頁即可散罕。
image.png

代碼實(shí)現(xiàn)

我們通過上面的嘗試寫了段代碼,發(fā)現(xiàn) B 站在一定程度上做了反爬蟲操作傀蓉,所以我們需要先獲取 headers 信息欧漱,否則下載下來的視頻是空的,然后定義 params 參數(shù)存儲(chǔ) JSON 數(shù)據(jù)葬燎,然后通過 requests.get 去獲取其參數(shù)值信息误甚,用 JSON 的格式返回到目標(biāo)網(wǎng)頁即可缚甩,實(shí)現(xiàn)代碼如下:

def get_json(url):
 headers = {
 'User-Agent': 
 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36'
 }

 params = {
 'page_size': 10,
 'next_offset': str(num),
 'tag': '今日熱門',
 'platform': 'pc'
 }

 try:
 html = requests.get(url,params=params,headers=headers)
 return html.json()

 except BaseException:
 print('request error')
 pass

為了能夠清楚的看到我們下載的情況,我們折騰了一個(gè)下載器上去窑邦,實(shí)現(xiàn)代碼如下:

def download(url,path):
 start = time.time() # 開始時(shí)間
 size = 0
 headers = {
 'User-Agent': 
 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36'
 }

 response = requests.get(url,headers=headers,stream=True) # stream屬性必須帶上
 chunk_size = 1024 # 每次下載的數(shù)據(jù)大小
 content_size = int(response.headers['content-length']) # 總大小
 if response.status_code == 200:
 print('[文件大小]:%0.2f MB' %(content_size / chunk_size / 1024)) # 換算單位
 with open(path,'wb') as file:
 for data in response.iter_content(chunk_size=chunk_size):
 file.write(data)
 size += len(data) # 已下載的文件大小

效果如下:


image.png

將上面的代碼進(jìn)行匯總擅威,整個(gè)實(shí)現(xiàn)過程如下:

#!/usr/bin/env python#-*-coding:utf-8-*-import requestsimport randomimport timedef get_json(url):
 headers = {
 'User-Agent': 
 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36'
 }

 params = {
 'page_size': 10,
 'next_offset': str(num),
 'tag': '今日熱門',
 'platform': 'pc'
 }

 try:
 html = requests.get(url,params=params,headers=headers)
 return html.json()

 except BaseException:
 print('request error')
 passdef download(url,path):
 start = time.time() # 開始時(shí)間
 size = 0
 headers = {
 'User-Agent': 
 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36'
 }

 response = requests.get(url,headers=headers,stream=True) # stream屬性必須帶上
 chunk_size = 1024 # 每次下載的數(shù)據(jù)大小
 content_size = int(response.headers['content-length']) # 總大小
 if response.status_code == 200:
 print('[文件大小]:%0.2f MB' %(content_size / chunk_size / 1024)) # 換算單位
 with open(path,'wb') as file:
 for data in response.iter_content(chunk_size=chunk_size):
 file.write(data)
 size += len(data) # 已下載的文件大小

 if __name__ == '__main__':
 for i in range(10):
 url = 'http://api.vc.bilibili.com/board/v1/ranking/top?'
 num = i*10 + 1
 html = get_json(url)
 infos = html['data']['items']
 for info in infos:
 title = info['item']['description'] # 小視頻的標(biāo)題
 video_url = info['item']['video_playurl'] # 小視頻的下載鏈接
 print(title)

 # 為了防止有些視頻沒有提供下載鏈接的情況
 try:
 download(video_url,path='%s.mp4' %title)
 print('成功下載一個(gè)!')
 
 except BaseException:
 print('涼涼,下載失敗')
 pass

 time.sleep(int(format(random.randint(2,8)))) # 設(shè)置隨機(jī)等待時(shí)間

爬取效果圖如下:


image.png

結(jié)果:

image.png

似乎爬取的效果還可以,當(dāng)然喜歡的朋友不要忘記點(diǎn)贊分享轉(zhuǎn)發(fā)哦冈钦。

豆瓣.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末郊丛,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子瞧筛,更是在濱河造成了極大的恐慌厉熟,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,427評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件较幌,死亡現(xiàn)場離奇詭異揍瑟,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)乍炉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評論 3 395
  • 文/潘曉璐 我一進(jìn)店門绢片,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人岛琼,你說我怎么就攤上這事底循。” “怎么了槐瑞?”我有些...
    開封第一講書人閱讀 165,747評論 0 356
  • 文/不壞的土叔 我叫張陵熙涤,是天一觀的道長。 經(jīng)常有香客問我随珠,道長灭袁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,939評論 1 295
  • 正文 為了忘掉前任窗看,我火速辦了婚禮茸歧,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘显沈。我一直安慰自己软瞎,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評論 6 392
  • 文/花漫 我一把揭開白布拉讯。 她就那樣靜靜地躺著涤浇,像睡著了一般。 火紅的嫁衣襯著肌膚如雪魔慷。 梳的紋絲不亂的頭發(fā)上只锭,一...
    開封第一講書人閱讀 51,737評論 1 305
  • 那天,我揣著相機(jī)與錄音院尔,去河邊找鬼蜻展。 笑死喉誊,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的纵顾。 我是一名探鬼主播伍茄,決...
    沈念sama閱讀 40,448評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼施逾!你這毒婦竟也來了敷矫?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,352評論 0 276
  • 序言:老撾萬榮一對情侶失蹤汉额,失蹤者是張志新(化名)和其女友劉穎曹仗,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體闷愤,經(jīng)...
    沈念sama閱讀 45,834評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡整葡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評論 3 338
  • 正文 我和宋清朗相戀三年件余,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了讥脐。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,133評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡啼器,死狀恐怖旬渠,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情端壳,我是刑警寧澤告丢,帶...
    沈念sama閱讀 35,815評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站损谦,受9級特大地震影響岖免,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜照捡,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評論 3 331
  • 文/蒙蒙 一颅湘、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧栗精,春花似錦闯参、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至薪夕,卻和暖如春脚草,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背原献。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評論 1 272
  • 我被黑心中介騙來泰國打工馏慨, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留涩蜘,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,398評論 3 373
  • 正文 我出身青樓熏纯,卻偏偏與公主長得像同诫,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子樟澜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 大家平時(shí)空閑的時(shí)候都會(huì)有刷小視頻的習(xí)慣吧误窖,我也會(huì)在B站上看一些視頻,今天就和大家分享一個(gè)用Python寫的一個(gè)自動(dòng)...
    叫我小包總閱讀 1,771評論 0 0
  • B 站小視頻網(wǎng)址:http://vc.bilibili.com/p/eden/rank#/?tab=%E5%85%...
    失憶的蝴蝶閱讀 743評論 0 2
  • 文/西秦木子 杯子還是那個(gè)杯子 還在原來的地方 我坐在對面 時(shí)不時(shí)看一眼窗外變幻的天空 深呼吸秩贰,讓心情平靜 讓大把...
    西秦木子閱讀 300評論 0 5
  • 我怕別人說我丑于是我先自己說自己丑 我怕別人說我窮于是我先自己說自己窮 我怕別人欺騙傷害我于是我先試探別人保護(hù)自己...
    Gardenia_3094閱讀 139評論 0 0
  • 不對別人的生活過度關(guān)心霹俺,我的關(guān)注點(diǎn)在自己身上,我在意自己舒不舒服毒费,遠(yuǎn)超過好不好看丙唧。因?yàn)槭娣宰匀纾驗(yàn)樽匀缢院?..
    有點(diǎn)餓有點(diǎn)困閱讀 313評論 0 0