【NLP舆情分析】基于python微博舆情分析可视化系统(flask+pandas+echarts) 视频教程 - 微博舆情数据可视化分析-热词情感趋势柱状图

大家好,我是java1234_小锋老师,最近写了一套【NLP舆情分析】基于python微博舆情分析可视化系统(flask+pandas+echarts)视频教程,持续更新中,计划月底更新完,感谢支持。今天讲解微博舆情数据可视化分析-热词情感趋势柱状图

视频在线地址:

2026版【NLP舆情分析】基于python微博舆情分析可视化系统(flask+pandas+echarts+爬虫) 视频教程 (火爆连载更新中..)_哔哩哔哩_bilibili

课程简介:

本课程采用主流的Python技术栈实现,Mysql8数据库,Flask后端,Pandas数据分析,前端可视化图表采用echarts,以及requests库,snowNLP进行情感分析,词频统计,包括大量的数据统计及分析技巧。

实现了,用户登录,注册,爬取微博帖子和评论信息,进行了热词统计以及舆情分析,以及基于echarts实现了数据可视化,包括微博文章分析,微博IP分析,微博评论分析,微博舆情分析。最后也基于wordcloud库实现了词云图,包括微博内容词云图,微博评论词云图,微博评论用户词云图等功能。

微博舆情数据可视化分析-热词情感趋势柱状图

首先,我把微博舆情分析静态页面sentimentAnalysis.html贴到templates下:

复制代码
{% extends 'base.html' %}
{% block title %}舆情分析{% endblock %}
{% block content %}
    <div class="container-fluid">
        <div class="row">
            <div class="col-md-12 mb-4 mt-1">
                <div class="d-flex flex-wrap justify-content-between align-items-center">
                    <h4 class="font-weight-bold">舆情分析</h4>
​
                </div>
            </div>
        </div>
​
        <div class="row">
            <div class="col-lg-6">
                <div class="card">
                    <div class="card-header d-flex justify-content-between">
                        <div class="header-title">
                            <h4 class="card-title">热词情感趋势柱状图</h4>
                        </div>
                    </div>
                    <div class="card-body">
                        <div id="hotBarMain" style="width:100%;height:450px">
​
                        </div>
                    </div>
                </div>
​
            </div>
            <div class="col-lg-6">
                <div class="card">
                    <div class="card-header d-flex justify-content-between">
                        <div class="header-title">
                            <h4 class="card-title">热词情感趋势树形图</h4>
                        </div>
                    </div>
                    <div class="card-body">
                        <div id="hotTreeMapMain" style="width:100%;height:450px">
​
                        </div>
                    </div>
                </div>
            </div>
            <div class="col-lg-6">
                <div class="card">
                    <div class="card-header d-flex justify-content-between">
                        <div class="header-title">
                            <h4 class="card-title">文章内容与评论内容舆情趋势饼状图</h4>
                        </div>
                    </div>
                    <div class="card-body">
                        <div id="contentPieMain" style="width:100%;height:450px;text-align:center">
                        </div>
                    </div>
                </div>
            </div>
            <div class="col-lg-6">
                <div class="card">
                    <div class="card-header d-flex justify-content-between">
                        <div class="header-title">
                            <h4 class="card-title">热词TOP15</h4>
                        </div>
                    </div>
                    <div class="card-body">
                        <div id="hotData15Main" style="width:100%;height:450px;text-align:center">
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
{% endblock %}
{% block echarts %}
​
{% endblock %}

后端实现sentimentAnalysis方法:

复制代码
@pb.route('/sentimentAnalysis')
def sentimentAnalysis():
    """
    舆情数据分析
    :return:
    """
    xHotBarData = ['正面', '中性', '负面']
    yHotBarData = [0, 0, 0]
    # 只读取前100条
    df = pd.read_csv('./fenci/comment_fre.csv', nrows=100)
    for value in df.values:
        # 情感分析
        stc = SnowNLP(value[0]).sentiments
        if stc > 0.6:
            yHotBarData[0] += 1
        elif stc < 0.2:
            yHotBarData[2] += 1
        else:
            yHotBarData[1] += 1
    return render_template('sentimentAnalysis.html',
                           xHotBarData=xHotBarData,
                           yHotBarData=yHotBarData)

前端实现柱状图表代码:

复制代码
<script>
        var chartDom = document.getElementById('hotBarMain');
        var myChart = echarts.init(chartDom);
        var option;
        var colors = ['#66CC99', '#FFCC66', '#FF6666', '#6699CC'];
​
        option = {
            title: {
                text: '热词情感分析柱状图',
            },
            tooltip: {
                trigger: 'axis'
            },
            legend: {
                data: ['情感个数']
            },
            toolbox: {
                show: true,
                feature: {
                    dataView: {show: true, readOnly: false},
                    magicType: {show: true, type: ['line', 'bar']},
                    restore: {show: true},
                    saveAsImage: {show: true}
                }
            },
            calculable: true,
            xAxis: [
                {
                    type: 'category',
                    // prettier-ignore
                    data: {{ xHotBarData | tojson}}
                }
            ],
            yAxis: [
                {
                    type: 'value'
                }
            ],
            series: [
                {
                    name: '情感个数',
                    type: 'bar',
                    data: {{ yHotBarData }},
                    markPoint: {
                        data: [
                            {type: 'max', name: 'Max'},
                            {type: 'min', name: 'Min'}
                        ]
                    },
                    itemStyle: {
                        color: function (params) {
                            return colors[params.dataIndex % colors.length];
                        }
                    },
                    markLine: {
                        data: [{type: 'average', name: 'Avg'}]
                    }
                }
            ]
        };
​
        option && myChart.setOption(option);
​
    </script>
相关推荐
萧鼎2 小时前
深入理解 Python Scapy 库:网络安全与协议分析的瑞士军刀
开发语言·python·web安全
阿拉丁的梦4 小时前
教程1:用vscode->ptvsd-创建和调试一个UI(python)-转载官方翻译(有修正)
开发语言·python
名难取aaa5 小时前
celery solo acks_late得不到预期
python·celery
GIS开发特训营6 小时前
【智慧城市】2025年中国地质大学(武汉)暑期实训优秀作品(2):智慧城市西安与一带一路
人工智能·信息可视化·智慧城市
大翻哥哥7 小时前
Python地理空间数据分析:从地图绘制到智能城市应用
开发语言·python·数据分析
奇舞精选8 小时前
爬虫入门
爬虫·python
爬虫程序猿8 小时前
利用 Python 爬虫获取 1688 商品详情 API 返回值说明(代码示例)实战指南
开发语言·爬虫·python
明月看潮生9 小时前
编程与数学 02-017 Python 面向对象编程 23课题、测试面向对象的程序
开发语言·python·青少年编程·面向对象·编程与数学
小蒜学长10 小时前
基于django的梧桐山水智慧旅游平台设计与开发(代码+数据库+LW)
java·spring boot·后端·python·django·旅游
大千AI助手10 小时前
InstructGPT:使用人类反馈训练语言模型以遵循指令
人工智能·gpt·语言模型·自然语言处理·rlhf·指令微调·模型对齐