推广 热搜: page  红书  搜索  小红  哪些  数据  论文  数据分析  关键词  健身 

【可视化大屏教程】用Python开发智慧城市数据分析大屏

   日期:2025-01-02     移动:https://sicmodule.kub2b.com/mobile/quote/17968.html

目录

一、开发背景

二、讲解代码

2.1 大标题+背景图

2.2 各区县交通事故统计图-系列柱形图

2.3 图书馆建设率-水球图

2.4 当年城市空气质量aqi指数-面积图

2.5 近7年人均生产总值变化图-面积图

2.6 城市人才占比结构图-柱形图

2.7 城市宣传片视频-大屏左上角位置

2.8 组合以上图表,生成临时大屏

2.9 生成最终大屏

2.10 部署到服务器-供外部访问

三、在线演示


您好,我是 ,这是我独立开发的Python可视化大屏,看下演示效果

这个大屏,是通过pyecharts可视化开发框架实现。

下面详细介绍,这个大屏的实现过程。

:由于我的MySQL数据库环境问题,暂通过模拟假数据,对接可视化代码。

由于pyecharts组件没有专门用作标题的图表,我决定灵活运用Line组件实现大标题。

 

这里最关键的逻辑,就是背景图片的处理。我找了一张智慧城市的炫丽背景图片

然后用add_js_funcs代码把此图片设置为整个大屏的背景图。

大标题效果

由于背景图片太大(4360x2910,只显示出了上半部分,恰恰是我预期的效果

针对城市交通事故统计数据,绘制系列柱形图

 

效果图如下

这种两两一组的柱形图,在pyecharts中叫做:系列柱形图,Bar with different series gap

图书馆建设率,采用pyecharts的水球图(动态)展示效果

 

效果图如下(此处是静态截图,其实有动态波纹效果

城市空气质量aqi,采用面积图展示

 

效果图如下

与2.4章节逻辑实现相同,替换对应数据即可,不再赘述。

分别统计该城市的博士人才、硕士人才、本科人才、专科人才、专科以下的占比情况,通过柱形图展示

 

效果图如下

难点来了

pyecharts本身并无播放视频的组件,怎么实现的视频播放呢

首先,任意开发一个简单的图表,柱形图、折线图、散点图什么都可以,后续把它拖拽到大屏左上角。

最后我会用宣传片视频替换掉这个图表。

通过pyecharts提供的Page组件,采用DraggablePageLayout的layout方法,组合大屏

 

至此,临时大屏文件已经生成。

下面就开始手动拖拽,拖拽的过程,就不文字阐述了,可点击这个视频,观看拖拽过程

很关键

除了常规的拖拽组合大屏操作外,还记得2.7章节留下的疑问吗

定义一个存放视频的div,把它存到一个字符串里

 

注意看这行代码下面这行代码,把mp4视频文件放到static目录下

 

在临时html里找到左上角图表的代码部分,用正则表达式替换成这个视频的代码

 

最后,再执行常规生成最终大屏的代码

 

这样,就完成了把视频布局到大屏里的最终目的

最后,再看一次大屏演示效果

通过flask框架,将html大屏网页快速部署到服务器

 

需要注意的是,host设置为'0.0.0.0',不要把host设置为'127.0.0.1'或者'localhost',否则只能自己在本地访问,外部用户无法访问。

再多说一句,如果host设置没问题,外部用户仍然无法访问,请查看你的云服务器防火墙配置、端口映射、win出入站访问等安全策略,是否存在问题。

大屏演示地址:智慧城市数据可视化分析监控大屏

我的服务器是乞丐版的,带宽有限,左上角视频播放会卡顿,大家悠着点访问~~


本文首发公众号「老男孩的平凡之路」

我是 @马哥python说 ,持续分享python干货中

我是马哥,全网累计粉丝上万,欢迎一起交流python技术。

各平台搜索“马哥python说:知乎、哔哩哔哩、小红书、新浪微博。

本文地址:https://sicmodule.kub2b.com/quote/17968.html     企库往 https://sicmodule.kub2b.com/ , 查看更多

特别提示:本信息由相关用户自行提供,真实性未证实,仅供参考。请谨慎采用,风险自负。


0相关评论
相关最新动态
推荐最新动态
点击排行
网站首页  |  关于我们  |  联系方式  |  使用协议  |  版权隐私  |  网站地图  |  排名推广  |  广告服务  |  积分换礼  |  网站留言  |  RSS订阅  |  违规举报  |  鄂ICP备2020018471号