【爬蟲+數(shù)據(jù)清洗+可視化分析】輿情分析嗶哩嗶哩"陽(yáng)了"的評(píng)論

[toc]

一仗扬、背景介紹

您好繁扎,我是@馬哥python說油航,一枚10年程序猿。

以前大家見面都問"吃了沒"邢锯,最近大家見面都問"陽(yáng)了沒"扬蕊,奈何疫情反反復(fù)復(fù),惟愿身體安康丹擎!

我用python抓取了B站上千條評(píng)論尾抑,并進(jìn)行可視化輿情分析,下面詳細(xì)講解代碼蒂培。

二再愈、爬蟲代碼

2.1 展示爬取結(jié)果

首先,看下部分爬取數(shù)據(jù):
爬取數(shù)據(jù)

爬取字段含:視頻鏈接护戳、評(píng)論頁(yè)碼翎冲、評(píng)論作者、評(píng)論時(shí)間媳荒、IP屬地抗悍、點(diǎn)贊數(shù)、評(píng)論內(nèi)容肺樟。

2.2 爬蟲代碼講解

導(dǎo)入需要用到的庫(kù):

import requests  # 發(fā)送請(qǐng)求
import pandas as pd  # 保存csv文件
import os  # 判斷文件是否存在
import time
from time import sleep  # 設(shè)置等待檐春,防止反爬
import random  # 生成隨機(jī)數(shù)

定義一個(gè)請(qǐng)求頭:

# 請(qǐng)求頭
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'
}

請(qǐng)求頭中的cookie是個(gè)很關(guān)鍵的參數(shù)么伯,如果不設(shè)置cookie疟暖,會(huì)導(dǎo)致數(shù)據(jù)殘缺或無(wú)法爬取到數(shù)據(jù)。

那么cookie如何獲取呢?打開開發(fā)者模式俐巴,見下圖:
獲取cookie方式

由于評(píng)論時(shí)間是個(gè)十位數(shù):
ctime

所以開發(fā)一個(gè)函數(shù)用于轉(zhuǎn)換時(shí)間格式:

def trans_date(v_timestamp):
    """10位時(shí)間戳轉(zhuǎn)換為時(shí)間字符串"""
    timeArray = time.localtime(v_timestamp)
    otherStyleTime = time.strftime("%Y-%m-%d %H:%M:%S", timeArray)
    return otherStyleTime

向B站發(fā)送請(qǐng)求:

response = requests.get(url, headers=headers, )  # 發(fā)送請(qǐng)求

接收到返回?cái)?shù)據(jù)了骨望,怎么解析數(shù)據(jù)呢?看一下json數(shù)據(jù)結(jié)構(gòu):
json數(shù)據(jù)

0-19個(gè)評(píng)論欣舵,都存放在replies下面擎鸠,replies又在data下面,所以缘圈,這樣解析數(shù)據(jù):

data_list = response.json()['data']['replies']  # 解析評(píng)論數(shù)據(jù)

這樣劣光,data_list里面就是存儲(chǔ)的每條評(píng)論數(shù)據(jù)了。

接下來嗎糟把,就是解析出每條評(píng)論里的各個(gè)字段了绢涡。

我們以評(píng)論內(nèi)容這個(gè)字段為例:

comment_list = []  # 評(píng)論內(nèi)容空列表
# 循環(huán)爬取每一條評(píng)論數(shù)據(jù)
for a in data_list:
    # 評(píng)論內(nèi)容
    comment = a['content']['message']
    comment_list.append(comment)

其他字段同理,不再贅述遣疯。

最后雄可,把這些列表數(shù)據(jù)保存到DataFrame里面,再to_csv保存到csv文件缠犀,持久化存儲(chǔ)完成:

# 把列表拼裝為DataFrame數(shù)據(jù)
df = pd.DataFrame({
    '視頻鏈接': 'https://www.bilibili.com/video/' + v_bid,
    '評(píng)論頁(yè)碼': (i + 1),
    '評(píng)論作者': user_list,
    '評(píng)論時(shí)間': time_list,
    'IP屬地': location_list,
    '點(diǎn)贊數(shù)': like_list,
    '評(píng)論內(nèi)容': comment_list,
})
# 把評(píng)論數(shù)據(jù)保存到csv文件
df.to_csv(outfile, mode='a+', encoding='utf_8_sig', index=False, header=header)

注意数苫,加上encoding='utf_8_sig',否則可能會(huì)產(chǎn)生亂碼問題辨液!

下面虐急,是主函數(shù)循環(huán)爬取部分代碼:(支持多個(gè)視頻的循環(huán)爬取)

# 隨便找了幾個(gè)"世界杯"相關(guān)的視頻ID
bid_list = ['BV1DP411g7jx', 'BV1M24y117K3', 'BV1nt4y1N7Kj']
# 評(píng)論最大爬取頁(yè)(每頁(yè)20條評(píng)論)
max_page = 30
# 循環(huán)爬取這幾個(gè)視頻的評(píng)論
for bid in bid_list:
    # 輸出文件名
    outfile = 'b站評(píng)論_{}.csv'.format(now)
    # 轉(zhuǎn)換aid
    aid = bv2av(bid=bid)
    # 爬取評(píng)論
    get_comment(v_aid=aid, v_bid=bid)

三室梅、可視化代碼

為了方便看效果戏仓,以下代碼采用jupyter notebook進(jìn)行演示。

3.1 讀取數(shù)據(jù)

用read_csv讀取剛才爬取的B站評(píng)論數(shù)據(jù):
讀取數(shù)據(jù)

查看前3行及數(shù)據(jù)形狀:
查看前3行

3.2 數(shù)據(jù)清洗

處理空值及重復(fù)值:
數(shù)據(jù)清洗

3.3 可視化

3.3.1 IP屬地分析-柱形圖

柱形圖

可得結(jié)論:關(guān)于"陽(yáng)了"這個(gè)話題亡鼠,評(píng)論里關(guān)注度最高為廣東赏殃、北京、江蘇等地區(qū)间涵,其中仁热,廣東省的關(guān)注度最高。同時(shí)勾哩,我們注意到抗蠢,也包含一些海外網(wǎng)友的少量評(píng)論。

3.3.2 評(píng)論時(shí)間分析-折線圖

分析出評(píng)論時(shí)間的分布情況:
折線圖

可得結(jié)論:關(guān)于"陽(yáng)了"這個(gè)話題思劳,再抓取到的數(shù)據(jù)范圍內(nèi)迅矛,12.18日的評(píng)論數(shù)據(jù)量最大,達(dá)到了將近900的數(shù)量峰值潜叛。

3.3.3 點(diǎn)贊數(shù)分布-直方圖

由于點(diǎn)贊數(shù)大部分為0或個(gè)位數(shù)情況秽褒,個(gè)別點(diǎn)贊數(shù)到達(dá)成千上萬(wàn)壶硅,直方圖展示效果不佳,因此销斟,僅提取點(diǎn)贊數(shù)<30的數(shù)據(jù)繪制直方圖庐椒。
直方圖

可得結(jié)論:從直方圖的分布來看,點(diǎn)贊數(shù)在0-3個(gè)的評(píng)論占據(jù)大多數(shù)蚂踊,很少點(diǎn)贊數(shù)達(dá)到了上千上萬(wàn)的情況约谈。證明網(wǎng)友對(duì)"陽(yáng)了"事件的態(tài)度分布比較均勻,沒有出現(xiàn)態(tài)度非常聚集的評(píng)論內(nèi)容犁钟。

3.3.4 評(píng)論內(nèi)容-情感分布餅圖

針對(duì)中文評(píng)論數(shù)據(jù)棱诱,采用snownlp開發(fā)情感判定函數(shù):
情感判斷函數(shù)

情感分布餅圖,如下:
餅圖

可得結(jié)論:關(guān)于"陽(yáng)了"這個(gè)話題涝动,積極評(píng)價(jià)與消極評(píng)價(jià)占比差不多军俊,積極評(píng)價(jià)稍高一點(diǎn),反應(yīng)出網(wǎng)友對(duì)感染陽(yáng)性的態(tài)度反差很大捧存,大約各占一半。

3.3.5 評(píng)論內(nèi)容-詞云圖

初始化停用詞和詞云圖對(duì)象:
wordcloud對(duì)象

jieba分詞之后担败,對(duì)分詞后數(shù)據(jù)進(jìn)行繪制詞云圖:
詞云圖

可得結(jié)論:在詞云圖中昔穴,陽(yáng)、感染提前、發(fā)燒吗货、癥狀、疼狈网、嗓子等詞匯較大宙搬,出現(xiàn)頻率較高,反應(yīng)出眾多網(wǎng)友對(duì)確診陽(yáng)性后描述病癥拓哺、積極探討病情的現(xiàn)狀勇垛。

三、演示視頻

代碼演示視頻:
https://www.zhihu.com/zvideo/1590645358123839488


by 馬哥python說

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末士鸥,一起剝皮案震驚了整個(gè)濱河市闲孤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌烤礁,老刑警劉巖讼积,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異脚仔,居然都是意外死亡勤众,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門鲤脏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來们颜,“玉大人吕朵,你說我怎么就攤上這事≌谱” “怎么了边锁?”我有些...
    開封第一講書人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)波岛。 經(jīng)常有香客問我茅坛,道長(zhǎng),這世上最難降的妖魔是什么则拷? 我笑而不...
    開封第一講書人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任贡蓖,我火速辦了婚禮,結(jié)果婚禮上煌茬,老公的妹妹穿的比我還像新娘斥铺。我一直安慰自己,他們只是感情好坛善,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開白布晾蜘。 她就那樣靜靜地躺著,像睡著了一般眠屎。 火紅的嫁衣襯著肌膚如雪剔交。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,111評(píng)論 1 285
  • 那天改衩,我揣著相機(jī)與錄音岖常,去河邊找鬼。 笑死葫督,一個(gè)胖子當(dāng)著我的面吹牛竭鞍,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播橄镜,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼偎快,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了洽胶?” 一聲冷哼從身側(cè)響起滨砍,我...
    開封第一講書人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎妖异,沒想到半個(gè)月后惋戏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡他膳,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年响逢,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片棕孙。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡舔亭,死狀恐怖些膨,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情钦铺,我是刑警寧澤订雾,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站矛洞,受9級(jí)特大地震影響洼哎,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜沼本,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一噩峦、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧抽兆,春花似錦识补、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至贴妻,卻和暖如春导盅,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背揍瑟。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留乍炉,地道東北人绢片。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像岛琼,于是被迫代替她去往敵國(guó)和親底循。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345

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