目錄
- 一、背景介紹
- 二、爬蟲代碼
- 2.1 展示爬取結果
- 2.2 爬蟲代碼講解
- 三、可視化代碼
- 3.1 讀取資料
- 3.2 資料清洗
- 3.3 可視化
- 3.3.1 IP屬地分析-柱形圖
- 3.3.2 評論時間分析-折線圖
- 3.3.3 點贊數分布-直方圖
- 3.3.4 評論內容-情感分布餅圖
- 3.3.5 評論內容-詞云圖
- 四、演示視頻
- 五、附完整原始碼
一、背景介紹
您好,我是@馬哥python說,一枚10年程式猿,
2023開年這段時間,《狂飆》這部熱播劇引發全民追劇,不僅全員演技在線,更是符合反黑主旋律,因此創下多個收視率記錄!
基于此熱門事件,我用python抓取了B站上千條評論,并進行可視化輿情分析,下面詳細講解代碼,
二、爬蟲代碼
2.1 展示爬取結果
首先,看下部分爬取資料:

爬取欄位含:視頻鏈接、評論頁碼、評論作者、評論時間、IP屬地、點贊數、評論內容,
2.2 爬蟲代碼講解
匯入需要用到的庫:
import requests # 發送請求
import pandas as pd # 保存csv檔案
import os # 判斷檔案是否存在
import time
from time import sleep # 設定等待,防止反爬
import random # 生成亂數
定義一個請求頭:
# 請求頭
headers = {
'authority': 'api.bilibili.com',
'accept': 'application/json, text/plain, */*',
'accept-language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6',
# 需定期更換cookie,否則location爬不到
'cookie': "需換成自己的cookie值",
'origin': 'https://www.bilibili.com',
'referer': 'https://www.bilibili.com/video/BV1FG4y1Z7po/?spm_id_from=333.337.search-card.all.click&vd_source=69a50ad969074af9e79ad13b34b1a548',
'sec-ch-ua': '"Chromium";v="106", "Microsoft Edge";v="106", "Not;A=Brand";v="99"',
'sec-ch-ua-mobile': '?0',
'sec-ch-ua-platform': '"Windows"',
'sec-fetch-dest': 'empty',
'sec-fetch-mode': 'cors',
'sec-fetch-site': 'same-site',
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/106.0.0.0 Safari/537.36 Edg/106.0.1370.47'
}
請求頭中的cookie是個很關鍵的引數,如果不設定cookie,會導致資料殘缺或無法爬取到資料,
那么cookie如何獲取呢?打開開發者模式,見下圖:
?
由于評論時間是個十位數:
?
所以開發一個函式用于轉換時間格式:
def trans_date(v_timestamp):
"""10位時間戳轉換為時間字串"""
timeArray = time.localtime(v_timestamp)
otherStyleTime = time.strftime("%Y-%m-%d %H:%M:%S", timeArray)
return otherStyleTime
向B站發送請求:
response = requests.get(url, headers=headers, ) # 發送請求
接收到回傳資料了,怎么決議資料呢?看一下json資料結構:
?
0-19個評論,都存放在replies下面,replies又在data下面,所以,這樣決議資料:
data_list = response.json()['data']['replies'] # 決議評論資料
這樣,data_list里面就是存盤的每條評論資料了,
接下來嗎,就是決議出每條評論里的各個欄位了,
我們以評論內容這個欄位為例:
comment_list = [] # 評論內容空串列
# 回圈爬取每一條評論資料
for a in data_list:
# 評論內容
comment = a['content']['message']
comment_list.append(comment)
其他欄位同理,不再贅述,
最后,把這些串列資料保存到DataFrame里面,再to_csv保存到csv檔案,持久化存盤完成:
# 把串列拼裝為DataFrame資料
df = pd.DataFrame({
'視頻鏈接': 'https://www.bilibili.com/video/' + v_bid,
'評論頁碼': (i + 1),
'評論作者': user_list,
'評論時間': time_list,
'IP屬地': location_list,
'點贊數': like_list,
'評論內容': comment_list,
})
# 把評論資料保存到csv檔案
df.to_csv(outfile, mode='a+', encoding='utf_8_sig', index=False, header=header)
注意,加上encoding='utf_8_sig',否則可能會產生亂碼問題!
下面,是主函式回圈爬取部分代碼:(支持多個視頻的回圈爬取)
# 隨便找了幾個"狂飆"相關的視頻ID
bid_list = ['BV1Hx4y1E7QP', 'BV1Ev4y1r737', 'BV19x4y177ni']
# 評論最大爬取頁(每頁20條評論)
max_page = 50
# 回圈爬取這幾個視頻的評論
for bid in bid_list:
# 輸出檔案名
outfile = 'b站評論_{}.csv'.format(now)
# 轉換aid
aid = bv2av(bid=bid)
# 爬取評論
get_comment(v_aid=aid, v_bid=bid)
三、可視化代碼
為了方便看效果,以下代碼采用jupyter notebook進行演示,
3.1 讀取資料
用read_csv讀取剛才爬取的B站評論資料:
?
查看前3行及資料形狀:
?
3.2 資料清洗
處理空值及重復值:
?
3.3 可視化
3.3.1 IP屬地分析-柱形圖
?
可得結論:TOP10地區中,評論里關注度最高為廣東、山東、江蘇等地區,其中,廣東省的關注度最高,
3.3.2 評論時間分析-折線圖
分析出評論時間的分布情況:
?
可得結論:關于"狂飆"這個話題,在抓取到的資料范圍內,2月2日的評論資料量最大,網友討論最熱烈,達到了將近1200的數量峰值,
3.3.3 點贊數分布-直方圖
由于點贊數大部分為0或個位數情況,個別點贊數到達成千上萬,直方圖展示效果不佳,因此,僅提取點贊數<30的資料繪制直方圖,
?
可得結論:從直方圖的分布來看,點贊數在0-3個的評論占據大多數,很少點贊數達到了上千上萬的情況,證明網友對狂飆這部作品的態度分布比較均勻,沒有出現態度非常聚集的評論內容,
3.3.4 評論內容-情感分布餅圖
針對中文評論資料,采用snownlp開發情感判定函式:
?
情感分布餅圖,如下:
?
可得結論:關于狂飆這部電視劇,網友的評論情感以正面居多,占據了70.43%,說明這部電視劇獲得了網友們很高的評價,
3.3.5 評論內容-詞云圖
除了哈工大停用詞之外,還新增了自定義停用詞:
?
jieba分詞之后,對分詞后資料進行繪制詞云圖:
?
可得結論:在詞云圖中,陽、感染、發燒、癥狀、疼、嗓子等詞匯較大,出現頻率較高,反應出眾多網友對確診陽性后描述病癥、積極探討病情的現狀,
附原始背景圖,可對比看:(需要先人物摳圖)
?
四、演示視頻
代碼演示視頻:
https://www.zhihu.com/zvideo/1608856878666231808
五、附完整原始碼
完整原始碼:【爬蟲+資料清洗+可視化分析】輿情分析嗶哩嗶哩"狂飆"的評論
我是 @馬哥python說 ,持續分享python原始碼干貨中!
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/543972.html
標籤:Python
