大家好,我是java1234_小鋒老師,最近寫了一套【NLP輿情分析】基于python微博輿情分析可視化系統(flask+pandas+echarts)視頻教程,持續更新中,計劃月底更新完,感謝支持。今天講解微博文章數據可視化分析-點贊區間實現
視頻在線地址:
2026版【NLP輿情分析】基于python微博輿情分析可視化系統(flask+pandas+echarts+爬蟲) 視頻教程 (火爆連載更新中..)_嗶哩嗶哩_bilibili
課程簡介:
?
本課程采用主流的Python技術棧實現,Mysql8數據庫,Flask后端,Pandas數據分析,前端可視化圖表采用echarts,以及requests庫,snowNLP進行情感分析,詞頻統計,包括大量的數據統計及分析技巧。
實現了,用戶登錄,注冊,爬取微博帖子和評論信息,進行了熱詞統計以及輿情分析,以及基于echarts實現了數據可視化,包括微博文章分析,微博IP分析,微博評論分析,微博輿情分析。最后也基于wordcloud庫實現了詞云圖,包括微博內容詞云圖,微博評論詞云圖,微博評論用戶詞云圖等功能。
微博文章數據可視化分析-點贊區間實現
后端我們首先根據類別去查詢數據,然后初始化x軸數據,然后再遍歷數據,統計y軸數據。
@pb.route('/articleDataAnalysis')
def articleDataAnalysis():"""文章數據分析:return:"""arcTypeList = []df = pd.read_csv('./spider/arcType_data.csv')for value in df.values:arcTypeList.append(value[0])# 獲取請求參數,如果沒獲取到,給個默認值 第一個列表數據。defaultArcType = request.args.get('arcType', default=arcTypeList[0])articleList = articleDao.getArticleByArcType(defaultArcType)xDzData = [] ?# 點贊x軸數據rangeNum = 1000for item in range(0, 10):xDzData.append(str(rangeNum * item) + '-' + str(rangeNum * (item + 1)))xDzData.append('1萬+')yDzData = [0 for x in range(len(xDzData))] ?# 點贊y軸數據for article in articleList:for item in range(len(xDzData)):if int(article[4]) < rangeNum * (item + 1):yDzData[item] += 1breakelif int(article[4]) > 10000:yDzData[len(xDzData) - 1] += 1breakreturn render_template('articleDataAnalysis.html',arcTypeList=arcTypeList,defaultArcType=defaultArcType,xDzData=xDzData,yDzData=yDzData)
前端圖表用柱狀圖:
<script>// 獲取容器元素var barChart = document.getElementById('dzMain');
?// 初始化 ECharts 實例var myChart = echarts.init(barChart);// 自定義顏色方案var colors = ['#66CC99', '#FFCC66', '#FF6666', '#6699CC'];
?// 配置柱狀圖選項var option = {title: {text: '點贊區間統計'},tooltip: {trigger: 'item',formatter: '{a} <br/>{b}: {c} (個)'},legend: {},xAxis: {type: 'category',data: {{ xDzData|tojson }},axisLabel: {color: '#333' // 設置 x 軸刻度標簽顏色}},yAxis: {type: 'value',axisLabel: {color: '#333' // 設置 y 軸刻度標簽顏色}},series: [{name: '點贊數量',type: 'bar',
?data:{{ yDzData }},itemStyle: {color: function (params) {return colors[params.dataIndex % colors.length];}},animation: true, ?// 啟用動畫效果animationDuration: 1000, ?// 動畫持續時間(毫秒)animationEasing: 'elasticOut', ?// 動畫緩動函數emphasis: {itemStyle: {color: '#3398DB' ?// 高亮顯示的顏色}}}]};
?// 使用配置項顯示柱狀圖myChart.setOption(option);
?</script>