大家好,我是java1234_小鋒老師,最近寫了一套【NLP輿情分析】基于python微博輿情分析可視化系統(flask+pandas+echarts)視頻教程,持續更新中,計劃月底更新完,感謝支持。今天講解主頁-微博點贊量Top6實現
視頻在線地址:
2026版【NLP輿情分析】基于python微博輿情分析可視化系統(flask+pandas+echarts+爬蟲) 視頻教程 (火爆連載更新中..)_嗶哩嗶哩_bilibili
課程簡介:
本課程采用主流的Python技術棧實現,Mysql8數據庫,Flask后端,Pandas數據分析,前端可視化圖表采用echarts,以及requests庫,snowNLP進行情感分析,詞頻統計,包括大量的數據統計及分析技巧。
實現了,用戶登錄,注冊,爬取微博帖子和評論信息,進行了熱詞統計以及輿情分析,以及基于echarts實現了數據可視化,包括微博文章分析,微博IP分析,微博評論分析,微博輿情分析。最后也基于wordcloud庫實現了詞云圖,包括微博內容詞云圖,微博評論詞云圖,微博評論用戶詞云圖等功能。
主頁-微博點贊量Top6實現
我們再實現下微博點贊量Top6的功能。
articleDao實現getArticleTopZan方法:
def getArticleTopZan():"""獲取點贊最高的6條帖子:return:"""con = Nonetry:con = dbUtil.getCon()cursor = con.cursor()sql = "select text_raw,attitudes_count from t_article order by attitudes_count DESC LIMIT 0,6"cursor.execute(sql)return cursor.fetchall()except Exception as e:print(e)con.rollback()return Nonefinally:dbUtil.closeCon(con)
page.py的getHomePageData方法里調用dao方法獲取數據,然后返回到前端。
def getArticleTopZan():"""獲取點贊最高的6條帖子:return:"""con = Nonetry:con = dbUtil.getCon()cursor = con.cursor()sql = "select text_raw,attitudes_count from t_article order by attitudes_count DESC LIMIT 0,6"cursor.execute(sql)return cursor.fetchall()except Exception as e:print(e)con.rollback()return Nonefinally:dbUtil.closeCon(con)
index.html 獲取數據后,遍歷dom追加:
function truncateString(str, length) {if (str.length > length) {return str.slice(0, length) + '...';} else {return str;}}function getHomePageData() {$.get('/page/homePageData', function (result) {$('#totalArticle').text(result.totalArticle + '個')$('#topAuthor').text(result.topAuthor)$('#topRegion').text(result.topRegion)let topArticles = result.topArticles$("#topArticle").empty()for (let i = 0; i < topArticles.length; i++) {const article = topArticles[i]$("#topArticle").append('<li class="p-3 list-item d-flex justify-content-start align-items-center">' +'<div class="list-style-detail ml-3 mr-2">' +'<p class="mb-0">' + truncateString(article[0], 20) + '</p>' +'</div>' +'<div class="list-style-action d-flex justify-content-end ml-auto">' +'<h6 class="font-weight-bold">' + article[1] + '👍</h6>' +'</div>' +'</li>')}})}