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.mzph.cn/diannao/44120.shtml

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

相关文章

Qt 创建的窗口一闪而过【已解决】

Qt 创建的窗口一闪而过 引言一、详细的解决方案 - 附代码二、参考博文 引言 创建的窗口一闪而过,就是创建完立马被销毁了,常见情况是在一个函数中创建窗口并show() - 即创建在了栈上,函数结束局部变量(窗口)自动被释放。主流的解决方法有两种…

每日刷题(二分查找,匈牙利算法,逆序对)

目录 1.Sarumans Army 2.Catch That Cow 3.Drying 4.P3386 【模板】二分图最大匹配 5. Swap Dilemma 1.Sarumans Army 3069 -- Sarumans Army (poj.org) 这道题就是要求我们在给的的位置放入 palantir,每个 palantir有R大小的射程范围,要求求出最少…

生产订单执行明细表二开增加字段

文章目录 生产订单执行明细表二开增加字段业务背景业务需求方案设计详细设计和实现标准报表引入到应用标准报表和过滤扩展添加字段创建插件,挂载插件新建类库 Krystal.K3.SCGL.App.Report,添加引用创建类,继承报表原插件重写BuilderReportSql…

【微服务】Spring Cloud中如何使用Eureka

文章目录 强烈推荐引言主要功能Eureka 的架构使用示例Eureka Server 配置Eureka Client 配置示例服务服务发现调用示例 Spring Cloud如何实现服务的注册?1. 搭建 Eureka 服务注册中心2. 配置服务注册到 Eureka3. 验证服务注册 总结应用场景1. 动态服务发现2. 负载均衡3. 服务治…

基于Java中的SSM框架实现水稻朔源信息系统项目【项目源码】

基于Java中的SSM框架实现水稻朔源信息系统演示 SSM框架 SSM框架是基于Spring、SpringMVC以及Mybatis实现的针对JAVA WEB端应用的开发框架,通过SSM框架结构可以实现以上三种框架的优点集合,从而实现更加高效便捷的系统开发和呈现。该框架结构通过Spring框…

PolarisMesh源码系列——服务如何注册

前话 PolarisMesh(北极星)是腾讯开源的服务治理平台,致力于解决分布式和微服务架构中的服务管理、流量管理、配置管理、故障容错和可观测性问题,针对不同的技术栈和环境提供服务治理的标准方案和最佳实践。 PolarisMesh 官网&am…

280个地级市金融集聚水平数据(2006-2022年)

2006年-2022年280个地级市金融集聚水平数据整理资源-CSDN文库 金融集聚水平:衡量地级市金融发展的新维度 金融集聚水平是衡量一个地区金融发展程度的重要指标,它反映了金融机构、金融资源、金融服务在特定时间和空间的集中程度。这一指标的评估可以从多…

视语坤川大模型智能体平台亮相2024世界人工智能大会

7月4日-7月7日,以“以共商促共享以善治促善智”为主题的2024世界人工智能大会(WAIC 2024)在上海举办,世界顶级专家学者、知名企业代表、政界人士、高校组织等齐聚上海,共商发展、共话未来。 作为大会的重磅环节——昇…

【笔记】Android V 应用SDK升级适配和问题

说明 随着Google释放的Android版本,系统升级SDK到35,应用也需要升级上去,不然会报错。 Android Studio Jellyfish | 2023.3.1 | Android Developers Android Studio 预览版中的新功能 | Android Developers 当前版本的Android Studio

Elasticsearch:深度学习与机器学习:了解差异

作者:来自 Elastic Elastic Platform Team 近年来,两项突破性技术一直站在创新的最前沿 —— 机器学习 (machine learning - ML) 和深度学习 (deep learning - DL)。人工智能 (AI) 的这些子集远不止是流行语。它们是推动医疗保健、金融等各行业进步的关键…

Java面试八股之MySQL索引B+树、全文索引、哈希索引

MySQL索引B树、全文索引、哈希索引 注意:B树中B不是代表二叉树(binary),而是代表平衡(balance),因为B树是从最早的平衡二叉树演化而来,但是B树不是一个二叉树。 B树的高度一般在2~…

es是如何处理索引数据的变动的?

1 概述 es是如何处理索引数据的变动的? 或者说索引数据变动时,es会执行哪些操作? refresh、fsync、merge 和 flush 操作有何作用? es是如何确保即使es发生宕机数据也不丢失的? 在回答上述问题前,可以先…

文件操作和IO流

前言👀~ 上一章我们介绍了多线程进阶的相关内容,今天来介绍使用java代码对文件的一些操作 文件(file) 文件路径(Path) 文件类型 文件操作 文件系统操作(File类) 文件内容的读…

leetcode--恢复二叉搜索树

leetcode地址:恢复二叉搜索树 给你二叉搜索树的根节点 root ,该树中的 恰好 两个节点的值被错误地交换。请在不改变其结构的情况下,恢复这棵树 。 示例 1: 输入:root [1,3,null,null,2] 输出:[3,1,null…

AirPods Pro新功能前瞻:iOS 18的五大创新亮点

随着科技的不断进步,苹果公司一直在探索如何通过创新提升用户体验。iOS 18的推出,不仅仅是iPhone的一次系统更新,更是苹果生态链中重要一环——AirPods Pro的一次重大升级。 据悉,iOS 18将为AirPods Pro带来五项新功能&#xff0…

设计模式探索:观察者模式

1. 观察者模式 1.1 什么是观察者模式 观察者模式用于建立一种对象与对象之间的依赖关系,当一个对象发生改变时将自动通知其他对象,其他对象会相应地作出反应。 在观察者模式中有如下角色: Subject(抽象主题/被观察者&#xf…

详细分析@FunctionalInterface的基本知识(附Demo)

目录 前言1. 基本知识2. Demo 前言 Java的基本知识推荐阅读: java框架 零基础从入门到精通的学习路线 附开源项目面经等(超全)Spring框架从入门到学精(全) 1. 基本知识 FunctionalInterface 是 Java 8 引入的一个注…

外卖商城平台小程序的设计

管理员账户功能包括:系统首页,个人中心,用户管理,商家管理,骑手管理,商品类型管理,商品信息管理,订单信息管理 微信端账号功能包括:系统首页,商品信息&#…

模板初阶详解

目录 泛型编程函数模板函数模板概念函数模板格式函数模板的原理函数模板的实例化隐式实例化强制类型转换的疑惑 显式实例化 模板参数的匹配原则 类模板类模板的定义格式类模板的实例化 感谢各位大佬对我的支持,如果我的文章对你有用,欢迎点击以下链接 🐒&#x1f41…

微信小程序接口wx.getLocation违规导致封禁解决办法

1、找到站内信的这个封禁的通知(功能封禁的通知,而不是处理警告的通知) 2、点击通知会有申诉链接,点开申诉链接 申诉原因可参考下面的内容: 1.小程序哪些板块已除去收集地理位置、2.哪些板块需要收集地理位置、3.详细…