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

师从黑马程序员

基础地图使用

基础地图演示

视觉映射器

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

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()

国内疫情地图的构建

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")#设置生成的文件名

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

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")#设置生成的文件名

若有侵权,请联系作者

相关推荐

  1. Python 数据

    2024-04-07 06:14:02       54 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-07 06:14:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-07 06:14:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-07 06:14:02       82 阅读
  4. Python语言-面向对象

    2024-04-07 06:14:02       91 阅读

热门阅读

  1. 34-2 SSRF(服务器端请求伪造)漏洞 - SSRF相关函数

    2024-04-07 06:14:02       45 阅读
  2. React Native调用Android的原生功能

    2024-04-07 06:14:02       35 阅读
  3. SpringBoot 优雅的网络请求

    2024-04-07 06:14:02       34 阅读
  4. spring 和springBoot区别

    2024-04-07 06:14:02       26 阅读
  5. 期权的各种套利分类

    2024-04-07 06:14:02       35 阅读
  6. 效率系列(十) macOS软件管理工具

    2024-04-07 06:14:02       33 阅读
  7. 设计模式:策略模式示例

    2024-04-07 06:14:02       29 阅读
  8. 计算机网络路由的配置

    2024-04-07 06:14:02       34 阅读
  9. C语言预处理基础知识笔记

    2024-04-07 06:14:02       34 阅读
  10. YOLOv5实战记录03 数据集构建

    2024-04-07 06:14:02       30 阅读
  11. go | gin多服务 | goroutine | ReadTimeout&WriteTimeout

    2024-04-07 06:14:02       37 阅读
  12. ffmpeg 从现有视频中截取一段

    2024-04-07 06:14:02       37 阅读