Pyecharts绘制可视化地球实现示例

作者:周萝卜 时间:2021-03-18 17:18:48 

今天我们使用 Pyecharts 制作一个地球可视化项目,一起来看看吧

Let’s go!

数据处理

这里我们使用全球新冠感染人数的数据集作为我们的测试数据,先来看看数据的整体情况

import pandas as pd
df = pd.read_csv("owid-covid-data.csv")
df_0608 = df[df['date'] == '2022-06-08']
df_new = df_0608[pd.isna(df_0608['continent']) == False]
df_new

Output:

Pyecharts绘制可视化地球实现示例

我们选取0608这一天的数据,可以看到 total_cases 字段就是国家当前的累计总确诊人数

下面就提取国家和确诊人数

covid_data = df_new[['location', 'total_cases']].values.tolist()

Output:

Pyecharts绘制可视化地球实现示例

Pyecharts 绘图

通过 Pyecharts 绘制地球图,在官网上有很详细的例子,我们直接套用即可

首先导入相关库

import pyecharts.options as opts
from pyecharts.charts import MapGlobe

定义地球图函数并绘制

data = [x for _, x in covid_data]
low, high = min(data), max(data)
c = (
   MapGlobe()
   .add_schema()
   .add(
       maptype="world",
       series_name="World Covid Data",
       data_pair=covid_data,
       is_map_symbol_show=False,
       label_opts=opts.LabelOpts(is_show=False),
   )
   .set_global_opts(
       visualmap_opts=opts.VisualMapOpts(
           min_=low,
           max_=high,
           range_text=["max", "min"],
           is_calculable=True,
           range_color=["lightskyblue", "yellow", "orangered"],
       )
   )
)
c.render_notebook()

这样我们得到如下全球各国新管确诊人数分布图

Pyecharts绘制可视化地球实现示例

部署为 Web 服务

当前我们所有的代码都是运行在 Jupyter 当中的,如果要分享给其他人,并不是十分的方便,我们可以将整体代码部署成一个 Web 服务,这样其他人就可以方便的通过浏览器来查看该地球图了

我们先创建项目目录,命名为 flask_map,再将本地安装的 Pyecharts 目录下的 templates 文件夹拷贝到该目录下,同时再创建 data 文件夹和 main.py 文件,Pyecharts 模板位置如下:

pyecharts.render.templates

我们将数据集 owid-covid-data.csv 放到 data 文件夹下,再编写 main.py 文件

# coding = utf-8
"""
======================
@author:luobo
@time:2022/7/2:14:32
@email:
@File: main.py
======================
"""
from flask import Flask, render_template
from jinja2 import Markup, Environment, FileSystemLoader
from pyecharts.globals import CurrentConfig
# 关于 CurrentConfig,可参考 [基本使用-全局变量]
CurrentConfig.GLOBAL_ENV = Environment(loader=FileSystemLoader("./templates"))
from pyecharts import options as opts
from pyecharts.charts import MapGlobe
import pandas as pd
df = pd.read_csv("data/owid-covid-data.csv")
df_0608 = df[df['date'] == '2022-06-08']
df_new = df_0608[pd.isna(df_0608['continent']) == False]
covid_data = df_new[['location', 'total_cases']].values.tolist()
app = Flask(__name__, static_folder="templates")
def Map_base():
   data = [x for _, x in covid_data]
   low, high = min(data), max(data)
   c = (
       MapGlobe()
           .add_schema()
           .add(
           maptype="world",
           series_name="World Covid Data",
           data_pair=covid_data,
           is_map_symbol_show=False,
           label_opts=opts.LabelOpts(is_show=False),
       )
           .set_global_opts(
           visualmap_opts=opts.VisualMapOpts(
               min_=low,
               max_=high,
               range_text=["max", "min"],
               is_calculable=True,
               range_color=["lightskyblue", "yellow", "orangered"],
           )
       )
   )
   return c
@app.route("/")
def index():
   c = Map_base()
   c.render('templates/Map.html')
   return render_template("Map.html")
if __name__ == "__main__":
   app.run()

这样,当我们启动 Flask 服务器之后,只需要访问根目录(/),就会在 templates 目录下生成 Map.html 文件,也会在浏览器正常展示地球图了

Pyecharts绘制可视化地球实现示例

tup2

至于如何将本地 Web 应用部署到公网上,我们在后面的文章中再介绍吧!

来源:https://juejin.cn/post/7124632143895986183

标签:Pyecharts,绘制,可视化,地球
0
投稿

猜你喜欢

  • 分析python切片原理和方法

    2021-04-19 21:39:03
  • Django-Rest-Framework 权限管理源码浅析(小结)

    2021-11-02 06:18:49
  • mysql误删root用户恢复方法

    2024-01-22 01:44:18
  • python读写配置文件操作示例

    2021-12-12 03:51:29
  • pandas行和列的获取的实现

    2022-06-05 07:57:49
  • node.js应用后台守护进程管理器Forever安装和使用实例

    2024-05-03 15:36:48
  • python中copy()与deepcopy()的区别小结

    2022-02-22 19:39:14
  • Python测试Kafka集群(pykafka)实例

    2023-05-05 20:57:56
  • 详细整理python 字符串(str)与列表(list)以及数组(array)之间的转换方法

    2022-03-16 09:40:28
  • php strftime函数的详细用法

    2023-06-07 19:09:37
  • 关于keras多任务多loss回传的思考

    2023-09-16 18:58:47
  • Python的for和break循环结构中使用else语句的技巧

    2022-07-02 16:59:26
  • 如何提高ASP的效率?

    2010-06-07 20:52:00
  • Vue生命周期实例分析总结

    2024-06-07 15:23:38
  • Python安装xarray库读取.nc文件的详细步骤

    2023-10-15 11:59:37
  • sqlserver中获取月份的天数的方法分享

    2011-09-30 11:27:52
  • python3实现语音转文字(语音识别)和文字转语音(语音合成)

    2022-10-02 03:40:33
  • Django框架实现的普通登录案例【使用POST方法】

    2021-10-12 18:05:10
  • 关于msyql事务隔离你要知道

    2024-01-27 11:07:31
  • 解决mysql输入密码闪退的问题

    2024-01-21 02:29:14
  • asp之家 网络编程 m.aspxhome.com