Pyecharts炫酷热力图:参数详解与实战大揭秘

news2024/9/23 3:23:25

Pyecharts绘制多种炫酷热力图参数说明+代码实战

引言

热力图在数据可视化中是一种强大的工具,可以直观地展示数据的分布情况和变化趋势。Pyecharts是一个基于Echarts的Python可视化库,提供了丰富的图表类型,包括热力图。在本文中,我们将深入探讨Pyecharts绘制多种炫酷热力图的参数说明和实际代码实战。

准备工作

首先,确保你已经安装了Pyecharts库。如果没有安装,可以使用以下命令进行安装:

pip install pyecharts

接下来,我们将使用一些示例数据来演示多种炫酷热力图的绘制。

# 导入必要的库
from pyecharts import options as opts
from pyecharts.charts import HeatMap
import random

# 生成示例数据
data = [[i, j, random.randint(0, 100)] for i in range(24) for j in range(7)]

基础热力图

首先,让我们创建一个基础的热力图。基础热力图只需提供数据和坐标轴信息即可。

# 创建基础热力图
heatmap_basic = (
    HeatMap()
    .add_xaxis(list(range(24)))
    .add_yaxis(
        series_name="",
        yaxis_data=list(range(7)),
        value= data,
        label_opts=opts.LabelOpts(is_show=True, position="inside"),
    )
    .set_global_opts(
        title_opts=opts.TitleOpts(title="基础热力图示例"),
        visualmap_opts=opts.VisualMapOpts(),
    )
)
# 渲染图表
heatmap_basic.render("heatmap_basic.html")

在这个基础热力图中,我们使用了add_xaxisadd_yaxis方法分别指定x轴和y轴的数据,value参数传入了我们准备好的示例数据。label_opts用于显示数据标签,set_global_opts用于设置全局选项,包括标题和视觉映射。

自定义热力图

接下来,让我们创建一个自定义热力图,调整颜色映射、热力点大小和其他样式。

# 创建自定义热力图
heatmap_custom = (
    HeatMap()
    .add_xaxis(list(range(24)))
    .add_yaxis(
        series_name="",
        yaxis_data=list(range(7)),
        value= data,
        label_opts=opts.LabelOpts(is_show=True, position="inside"),
        itemstyle_opts=opts.ItemStyleOpts(
            color="green", opacity=0.7, border_color="white", border_width=1
        ),
    )
    .set_global_opts(
        title_opts=opts.TitleOpts(title="自定义热力图示例"),
        visualmap_opts=opts.VisualMapOpts(
            min_=0, max_=100, range_color=["#F5DEB3", "#FF6347", "#800000"]
        ),
    )
)
# 渲染图表
heatmap_custom.render("heatmap_custom.html")

在这个示例中,我们通过itemstyle_opts参数调整了热力点的颜色、透明度、边框颜色和边框宽度。visualmap_opts用于调整视觉映射的范围和颜色。
在这里插入图片描述

炫酷动态热力图

最后,我们来创建一个炫酷的动态热力图,展示数据随时间的变化。

# 创建动态热力图
heatmap_dynamic = (
    HeatMap()
    .add_xaxis(list(range(24)))
    .add_yaxis(
        series_name="",
        yaxis_data=list(range(7)),
        value= data,
        label_opts=opts.LabelOpts(is_show=True, position="inside"),
    )
    .set_global_opts(
        title_opts=opts.TitleOpts(title="动态热力图示例"),
        visualmap_opts=opts.VisualMapOpts(),
        timeline_opts=opts.TimelineOpts(
            is_auto_play=True,
            play_interval=500,
            pos_bottom="5%",
            pos_left="center",
        ),
    )
)
# 添加时间轴数据
for i in range(7):
    heatmap_dynamic.add(
        series_name="",
        data_pair=list(zip(list(range(24)), [i] * 24, [random.randint(0, 100) for _ in range(24)])),
    )
# 渲染图表
heatmap_dynamic.render("heatmap_dynamic.html")

在动态热力图中,我们通过timeline_opts参数启用时间轴,然后通过add方法逐步添加每个时间点的数据。is_auto_play用于设置是否自动播放,play_interval设置播放间隔。

炫酷热力图的更多定制化

除了基础、自定义和动态热力图外,Pyecharts还提供了更多高级的定制化选项,使你能够创建炫酷且个性化的热力图。

空间热力图

有时候,我们需要在空间中展示数据的分布情况。以下是一个简单的三维热力图的例子:

from pyecharts.charts import Scatter3D

# 生成示例数据
data_3d = [[i, j, random.randint(0, 100)] for i in range(24) for j in range(7)]

# 创建三维热力图
scatter3d = (
    Scatter3D()
    .add("", data_3d)
    .set_global_opts(
        title_opts=opts.TitleOpts(title="三维热力图示例"),
        visualmap_opts=opts.VisualMapOpts(
            min_=0, max_=100, range_color=["#F5DEB3", "#FF6347", "#800000"]
        ),
    )
)
# 渲染图表
scatter3d.render("3d_heatmap.html")

这个例子中,我们使用了Scatter3D图表来创建三维散点图,通过visualmap_opts设置了颜色映射。
在这里插入图片描述

地图热力图

如果你有地理空间数据,你可以使用地图热力图来展示数据在地图上的分布情况。以下是一个简单的地图热力图的例子:

from pyecharts.charts import Geo

# 生成示例数据
data_geo = [(f"City{i}", random.randint(0, 100)) for i in range(1, 6)]

# 创建地图热力图
geo = (
    Geo()
    .add_schema(maptype="china")
    .add(
        "热力图",
        data_geo,
        type_=ChartType.HEATMAP,
        label_opts=opts.LabelOpts(is_show=True),
    )
    .set_global_opts(
        title_opts=opts.TitleOpts(title="地图热力图示例"),
        visualmap_opts=opts.VisualMapOpts(
            min_=0, max_=100, range_color=["#F5DEB3", "#FF6347", "#800000"]
        ),
    )
)
# 渲染图表
geo.render("map_heatmap.html")

在这个例子中,我们使用了Geo图表,通过add_schema添加了地图信息,然后通过add方法添加了热力图数据。

热力图的交互功能

Pyecharts提供了丰富的交互功能,使用户可以更灵活地探索热力图数据。以下是一个带有工具栏和数据缩放的热力图的例子:

# 创建交互热力图
heatmap_interactive = (
    HeatMap()
    .add_xaxis(list(range(24)))
    .add_yaxis(
        series_name="",
        yaxis_data=list(range(7)),
        value= data,
        label_opts=opts.LabelOpts(is_show=True, position="inside"),
    )
    .set_global_opts(
        title_opts=opts.TitleOpts(title="交互热力图示例"),
        visualmap_opts=opts.VisualMapOpts(),
        toolbox_opts=opts.ToolboxOpts(is_show=True, feature={"save_as_image": {}}),
        datazoom_opts=opts.DataZoomOpts(orient="horizontal"),
    )
)
# 渲染图表
heatmap_interactive.render("heatmap_interactive.html")

在这个例子中,我们通过toolbox_opts添加了工具栏,datazoom_opts添加了数据缩放功能。

在这里插入图片描述

进阶应用:热力图与其他图表的联动

Pyecharts提供了强大的图表联动功能,让你能够在一个页面上同时展示多个图表,并实现它们之间的联动。以下是一个热力图与折线图联动的例子:

from pyecharts.charts import Line

# 生成示例折线图数据
data_line = [random.randint(0, 100) for _ in range(24)]

# 创建联动图表
heatmap_linked = (
    HeatMap()
    .add_xaxis(list(range(24)))
    .add_yaxis(
        series_name="",
        yaxis_data=list(range(7)),
        value=data,
        label_opts=opts.LabelOpts(is_show=True, position="inside"),
    )
    .set_global_opts(
        title_opts=opts.TitleOpts(title="热力图与折线图联动示例"),
        visualmap_opts=opts.VisualMapOpts(),
        toolbox_opts=opts.ToolboxOpts(
            is_show=True, feature={"save_as_image": {}, "data_zoom": {}}
        ),
        datazoom_opts=opts.DataZoomOpts(orient="horizontal"),
    )
)

# 创建折线图
line_linked = (
    Line()
    .add_xaxis(list(range(24)))
    .add_yaxis("折线图", data_line, label_opts=opts.LabelOpts(is_show=False))
    .set_global_opts(
        title_opts=opts.TitleOpts(title="折线图示例"),
        toolbox_opts=opts.ToolboxOpts(
            is_show=True, feature={"save_as_image": {}, "data_zoom": {}}
        ),
        datazoom_opts=opts.DataZoomOpts(orient="horizontal"),
    )
)

# 使用Grid实现图表联动
grid = (
    Grid()
    .add(heatmap_linked, grid_opts=opts.GridOpts(pos_left="10%", pos_right="10%"))
    .add(line_linked, grid_opts=opts.GridOpts(pos_left="10%", pos_right="10%"))
)
# 渲染图表
grid.render("heatmap_line_linked.html")

在这个例子中,我们使用了Grid图表容器来将热力图和折线图放在同一个页面上,并通过grid_opts设置它们的位置。两个图表之间通过datazoom_opts实现了联动效果,可以通过工具栏的数据缩放功能来调整展示的时间范围。

通过掌握这些进阶应用,你可以更灵活地结合不同类型的图表,实现更复杂的数据展示和分析。

结语

本文深入探讨了Pyecharts绘制多种炫酷热力图的参数说明和代码实战。从基础的热力图到空间热力图、地图热力图,再到图表的联动,希望这些例子能够帮助你更好地应用Pyecharts进行数据可视化工作。随着你在使用Pyecharts的过程中的不断尝试和实践,你将能够更深入地理解和掌握这个强大的可视化库。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1421262.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

防御保护---防火墙的NAT-easyip

文章目录 目录 文章目录 点击此处查看NAT技术详解 一.NAT分类 二.防火墙配置 一对多NAT配置 多对多NAT配置 练习 点击此处查看NAT技术详解 一.NAT分类 源IP-NAT(源IP与公网之间转换):静态NAT,动态NAT,NAPT;使内网能够访问公网目…

Linux网络编程——网络初识

文章目录 1. 网络协议初识1.1 为什么要有网络协议1.2 协议分层 2. OSI七层模型3. TCP/IP五层(或四层)模型4. 网络传输基本流程5. 以太网通信 1. 网络协议初识 1.1 为什么要有网络协议 早期计算机是独立的,如果要进行数据交互,就…

安装好IntelliJ IDEA点击无反应,如何解决配置文件不一致导致的启动问题

在我们的开发生涯中,遇到IDE工具出现问题是在所难免的。最令人头疼的莫过于,你的IDEA(IntelliJ IDEA)无法启动,而且没有任何错误提示。这篇文章将详细讲解如何解决IntelliJ IDEA 2023.3.3版本启动失败的问题,这个问题可能也适用于…

【已解决】Centos安装不了podman问题(依赖无法安装)

今天安装podman一直安装不了,原因是containernetworking-plugins-1.1.1-1.el7.2.9.x86_64.rpm这个包因为网站的原因下载不了,不管是开启代理还是使用镜像源,都无法解决 最终是手动下载本地后上传至服务器解决,故把文件分享出来避…

【Web前端实操18】粘性定位——即固定顶层内容,可以继续滚动,但是顶层内容固定,不随着一起滚动

粘性定位 1、了解 可以被认为是相对定位和固定定位的混合。元素在跨越特定阈值前为相对定位,之后为固定定位。粘性定位是指网页或移动应用程序中的一种特性,即当用户滚动页面时,某个元素能够保持在屏幕上特定位置不动,直到用户滚动到达一定位置或进行特定操作。这个特性可…

【C++】C++入门—— 引用

引用 1 前情提要2 概念剖析3 引用特性4 常引用5 使用场景5.1做参数5.2 做返回值 6 传值 传引用的效率比较7 引用与指针的差异Thanks♪(・ω・)ノ谢谢阅读下一篇文章见 1 前情提要 在C语言中,我们往往会遇见复杂的指针(如…

tcpdump在手机上的使用

首先手机得root才可以,主要分析手机与手机的通信协议 我使用的是一加9pro, root方法参考一加全能盒子、一加全能工具箱官方网站——大侠阿木 (daxiaamu.com)https://optool.daxiaamu.com/index.php tcpdump,要安装在/data/local/tmp下要arm6…

vite+vue3+ts项目上线docker 配置反向代理API

这次重点的坑是反向代理。 1。项目中配置代理,为了跨域请求数据 项目根目录中新建vite.config.ts文件 在文件中添加配置代理 注意:其中 /api 和target 的地址后面没有 / 2。在项目根目录中新建Httprequest.ts文件,引入axios,并…

矩阵键盘的使用

在定义局部变量时,一定要给该变量赋初值。在这个程序中,给按键按下的返回值变量 KeyNum 赋值为 20 。 矩阵键盘线行扫描法的学习链接:https://www.bilibili.com/video/BV1dv411z7Gd/?spm_id_from333.999.0.0&vd_sourceb91967c499b23106…

推荐系统|概要_基本概念

文章目录 基本概念曝光点击相关指标点击率点赞率/收藏率/转发率阅读完成率总结北极星指标 实验流程 基本概念 曝光 笔记出现在首页,叫作曝光。 点击 用户从笔记表面进入到相关笔记的详情页,叫作一次点击。 除此之外,用户的喜爱&#xff0c…

Mybatis-Plus扩展

7 MybatisX插件[扩展] 7.1 MybatisX插件介绍 MybatisX 是一款基于 IDEA 的快速开发插件,为效率而生。 安装方法:打开 IDEA,进入 File -> Settings -> Plugins -> Browse Repositories,输入 mybatisx 搜索并安装。 功…

基于Springboot的视频网站系统的设计与实现(有报告)。Javaee项目,springboot项目。

演示视频: 基于Springboot的视频网站系统的设计与实现(有报告)。Javaee项目,springboot项目。 项目介绍: 采用M(model)V(view)C(controller)三层…

Java入门高频考查基础知识8(腾讯18问1.5万字参考答案)

刷题专栏:http://t.csdnimg.cn/gvB6r Java 是一种广泛使用的面向对象编程语言,在软件开发领域有着重要的地位。Java 提供了丰富的库和强大的特性,适用于多种应用场景,包括企业应用、移动应用、嵌入式系统等。 以下是几个面试技巧&…

Prometheus的pod部署

创建命名空间和账户以及集群账户 kubectl create ns monitor-sa kubectl create serviceaccount monitor -n monitor-sa kubectl create clusterrolebinding monitor-clusterrolebinding -n monitor-sa --clusterrolecluster-admin --serviceaccountmonitor-sa:monitor 创建…

电动汽车|不同类型电动汽车充电负荷蒙特卡洛法模拟研究(包括常规充电、快速充电、更换电池)

目录 主要内容 结果一览 常规充电 快速充电 更换电池 详实文档资料 下载链接 主要内容 本程序采用蒙特卡洛模拟了不同类型电动汽车充电负荷特点,包括常规充电、快速充电和更换电池三种。 充放电行为分为无序充电行为、受控充电行为和受控充放电行为…

大专生能不能学习鸿蒙开发?

目前安卓有2,000万的开发者。本科及以上学历占比为35%;iOS有2,400万开发者,本科及以上学历占比为40% 绝大多数的前端开发者都是大专及以下学历,在2023年华为开发者大会上余承东透露华为的开发者目前有200万,但鸿蒙开发者统计的数据…

【MyBatis】快速入门MyBatis(保姆式教学),你值得一看

文章目录 📄前言一. Mybatis简介✈️1. 什么是Mybatis🚀2. 为什么使用Mybatis 二. Mybatis快速入门🍆1. mybatis使用前准备1.1 创建springboot项目并引入相关依赖1.2 在 application.ym中进行数据源的配置1.3 创建数据表,准备表数…

【竞技宝jjb.lol】LOL:经典大龙毁一生 WE鏖战三局力克FPX

北京时间2024年1月30日,英雄联盟LPL2024春季赛在昨天迎来第二周首个比赛日,本日首场比赛由WE对阵FPX。本场比赛双方前两局战至1-1平,决胜局FPX一度建立不小的经济优势,然而太过冒险的打大龙决策最终让其功亏一篑,WE鏖战…

备战蓝桥杯---数据结构与STL应用(基础3)

今天我们主要介绍的是pair,string,set,map pair:我们可以把它当作一个结构体&#xff1a; void solve(){pair<int int> a;//创建amake_pair(1,2);//添加元素cout<<a.first<<endl<<a.second<<endl;}//输出 当然&#xff0c;它也可以嵌套&#…

Web自动化—Cypress 测试框架概述

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 关注公众号&#xff1a;互联网杂货铺&#xff0c;回复1 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;薪资嘎嘎涨 Cypress 测试框架概述 1.1 Cypress 默认文件结构 在C…