数据可视化-地图可视化-Python

师从黑马程序员

基础地图使用

基础地图演示

视觉映射器

具体颜色对应的代码可以在http://www.ab173.com/中查询RGB颜色查询对照表

python 复制代码
from pyecharts.charts import Map
from pyecharts.options import VisualMapOpts

#准备地图对象
map=Map()
#准备数据
data=[
    ("北京",99),
    ("上海",199),
    ("湖南",299),
    ("台湾",399),
    ("广东",499)
]
#添加数据
map.add("测试地图",data,"china")

#设置全局选项
map.set_global_opts(
    visualmap_opts=VisualMapOpts(
        is_show=True,
        is_piecewise=True,#允许手动校准
        pieces=[
            {"min":1,"max":9,"lable":"1-9","color":"#CCFFFF"},
            {"min":10,"max":99,"lable":"10-99","color":"#FF6666"},
            {"min":100,"max":500,"lable":"100-500","color":"#990033"}

        ]

    )
)

#绘图
map.render()

国内疫情地图的构建

python 复制代码
import json
from pyecharts.charts import Map
from pyecharts.options import *

f=open ("D:/疫情.txt","r",encoding="UTF-8")
#读取数据文件
data=f.read()
#关闭文件
f.close()
#取到各省的数据
#将字符串json转化为python的字典
data_dict=json.loads(data)
#从字典中取到各省的数据
province_data_list=data_dict["areaTree"][0]["children"]
#组装每个省份和确诊人数为元组  并将各个省份的数据都封装到列表内
data_list=[]  #绘图需要用到的数据列表
for province_data in province_data_list:
    province_name=province_data["name"]                     #省份名称
    province_confirm=province_data["total"]["confirm"]      #确诊人数
    data_list.append((province_name,province_confirm))

#创建地图对象
map=Map()
#添加数据
map.add("各省确诊人数",data_list,"china")
#设置全局配置,定制分段的视觉映射
map.set_global_opts(
    title_opts=TitleOpts(title="全国疫情地图"),#设置标题
    visualmap_opts=VisualMapOpts(
        is_show=True,#是否显示
        is_piecewise=True,#是否分段
        pieces=[
            {"min":1,"max":99,"lable":"1-99人","color":"#CCFFFF"},
            {"min":100,"max":999,"lable":"100-999人","color":"#FFFF99"},
            {"min":1000,"max":4999,"lable":"1000-4999人","color":"#=FF9966"},
            {"min":5000,"max":9999,"lable":"5000-9999人","color":"FF6666"},
            {"min":10000,"max":99999,"lable":"10000-99999人","color":"#CC3333"},
            {"min":100000,"lable":"100000+","color":"#990033"}

        ]
    )
)
#绘图
map.render("全国疫情地图.html")#设置生成的文件名

疫情地图-省级疫情地图(以河南省为例)

python 复制代码
import json
from pyecharts.charts import Map
from pyecharts.options import *

f=open ("D:/疫情.txt","r",encoding="UTF-8")
#读取数据文件
data=f.read()
#关闭文件
f.close()
#获取到河南省数据
#将字符串json转化为python的字典
data_dict=json.loads(data)
#从字典中取到河南省的数据
cities_data=data_dict["areaTree"][0]["children"][3]["children"]
#准备数据为元组并放到list
data_list=[]
for city_data in cities_data:
    city_name=city_data["name"]   +"市"                  #省份名称
    city_confirm=city_data["total"]["confirm"]      #确诊人数
    data_list.append((city_name,city_confirm))
#手动添加济源市数据
data_list.append(("济源市",5))
#创建地图对象
map=Map()
#添加数据
map.add("河南疫情分布",data_list,"河南")
#设置全局配置,定制分段的视觉映射
map.set_global_opts(
    title_opts=TitleOpts(title="河南省疫情地图"),#设置标题
    visualmap_opts=VisualMapOpts(
        is_show=True,#是否显示
        is_piecewise=True,#是否分段
        pieces=[
            {"min":1,"max":99,"lable":"1-99人","color":"#CCFFFF"},
            {"min":100,"max":999,"lable":"100-999人","color":"#FFFF99"},
            {"min":1000,"max":4999,"lable":"1000-4999人","color":"#=FF9966"},
            {"min":5000,"max":9999,"lable":"5000-9999人","color":"FF6666"},
            {"min":10000,"max":99999,"lable":"10000-99999人","color":"#CC3333"},
            {"min":100000,"lable":"100000+","color":"#990033"}

        ]
    )
)

#绘图
map.render("河南省疫情地图.html")#设置生成的文件名

若有侵权,请联系作者

相关推荐
qq_417695054 小时前
机器学习与人工智能
jvm·数据库·python
漫随流水4 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
yy我不解释5 小时前
关于comfyui的mmaudio音频生成插件时时间不一致问题(一)
python·ai作画·音视频·comfyui
紫丁香6 小时前
AutoGen详解一
后端·python·flask
FreakStudio6 小时前
不用费劲编译ulab了!纯Mpy矩阵micronumpy库,单片机直接跑
python·嵌入式·边缘计算·电子diy
清水白石0088 小时前
Free-Threaded Python 实战指南:机遇、风险与 PoC 验证方案
java·python·算法
飞Link8 小时前
具身智能核心架构之 Python 行为树 (py_trees) 深度剖析与实战
开发语言·人工智能·python·架构
桃气媛媛9 小时前
Pycharm常用快捷键
python·pycharm
Looooking10 小时前
Python 之获取安装包所占用磁盘空间大小
python
WenGyyyL10 小时前
ColBERT论文研读——NLP(IR)里程碑之作
人工智能·python·语言模型·自然语言处理