精通Python第13篇—数据之光:Pyecharts旭日图的魔法舞台

文章目录

    • 引言
    • 准备工作
    • 绘制基本旭日图
    • 调整颜色和样式
    • 添加交互功能
    • 定制标签和标签格式
    • 嵌套层级数据
    • 高级样式与自定义
    • 进阶主题:动态旭日图
    • 数据源扩展:外部JSON文件
    • 总结

引言

数据可视化在现代编程中扮演着重要的角色,而Pyecharts是Python中一个强大的图表库,可以轻松实现各种炫酷的数据可视化效果。其中,旭日图是一种展示层次结构数据的理想选择,通过不同的颜色和半径呈现数据的层级和关系。在本篇技术博客中,我们将深入探讨Pyecharts中绘制旭日图的多种参数,同时提供实用的代码示例,帮助你更好地利用这一功能。
在这里插入图片描述

准备工作

在开始之前,请确保你已经安装了Pyecharts库。如果没有安装,可以使用以下命令进行安装:

pip install pyecharts

绘制基本旭日图

首先,我们从最基本的旭日图开始,使用Pyecharts的Sunburst类。

from pyecharts import options as opts
from pyecharts.charts import Sunburstdata = {"name": "root","children": [{"name": "A", "value": 10},{"name": "B", "value": 20},{"name": "C", "value": 15},{"name": "D", "value": 25},],
}sunburst = Sunburst()
sunburst.add("", data['children'], radius=[0, "90%"])
sunburst.set_global_opts(title_opts=opts.TitleOpts(title="基本旭日图"))
sunburst.render("basic_sunburst.html")

在上述代码中,我们定义了一个简单的层级结构数据,然后使用Sunburst类绘制了基本的旭日图。radius参数用于设置旭日图的半径范围。
在这里插入图片描述

调整颜色和样式

为了让旭日图更具吸引力,我们可以调整颜色和样式。

from pyecharts import options as opts
from pyecharts.charts import Sunburstdata = {"name": "root","children": [{"name": "A", "value": 10},{"name": "B", "value": 20},{"name": "C", "value": 15},{"name": "D", "value": 25},],
}sunburst = Sunburst()
sunburst.add("", data['children'], radius=[0, "90%"], color_scheme="purple")
sunburst.set_global_opts(title_opts=opts.TitleOpts(title="调整颜色和样式"),legend_opts=opts.LegendOpts(is_show=False),
)
sunburst.render("styled_sunburst.html")

在这个例子中,我们使用了color_scheme参数来指定颜色方案,并通过legend_opts隐藏了图例。

添加交互功能

为了增强用户体验,我们可以添加一些交互功能,如数据提示和缩放。

from pyecharts import options as opts
from pyecharts.charts import Sunburstdata = {"name": "root","children": [{"name": "A", "value": 10},{"name": "B", "value": 20},{"name": "C", "value": 15},{"name": "D", "value": 25},],
}sunburst = Sunburst()
sunburst.add("", data['children'], radius=[0, "90%"], color_scheme="purple")
sunburst.set_global_opts(title_opts=opts.TitleOpts(title="添加交互功能"),legend_opts=opts.LegendOpts(is_show=False),tooltip_opts=opts.TooltipOpts(trigger="item", formatter="{b}: {c}"),toolbox_opts=opts.ToolboxOpts(is_show=True, feature={"saveAsImage": {}}),
)
sunburst.render("interactive_sunburst.html")

在这个例子中,我们通过tooltip_opts添加了数据提示,toolbox_opts增加了保存为图片的功能。

定制标签和标签格式

在旭日图中,标签对于传达信息非常重要。我们可以通过label_opts参数来定制标签的样式和格式。

from pyecharts import options as opts
from pyecharts.charts import Sunburstdata = {"name": "root","children": [{"name": "A", "value": 10},{"name": "B", "value": 20},{"name": "C", "value": 15},{"name": "D", "value": 25},],
}sunburst = Sunburst()
sunburst.add("",data['children'],radius=[0, "90%"],color_scheme="purple",label_opts=opts.LabelOpts(formatter="{b}: {c}", position="inside"),
)
sunburst.set_global_opts(title_opts=opts.TitleOpts(title="定制标签和标签格式"),legend_opts=opts.LegendOpts(is_show=False),
)
sunburst.render("custom_label_sunburst.html")

在上述代码中,我们使用了label_opts参数来设置标签的格式和位置,通过formatter来自定义标签的显示内容。

嵌套层级数据

如果你的数据包含多个层级,你可以通过嵌套的方式表示。

from pyecharts import options as opts
from pyecharts.charts import Sunburstdata = {"name": "root","children": [{"name": "A","children": [{"name": "A1", "value": 10},{"name": "A2", "value": 20},],},{"name": "B","children": [{"name": "B1", "value": 15},{"name": "B2", "value": 25},],},],
}sunburst = Sunburst()
sunburst.add("", data['children'], radius=[0, "90%"], color_scheme="purple")
sunburst.set_global_opts(title_opts=opts.TitleOpts(title="嵌套层级数据"),legend_opts=opts.LegendOpts(is_show=False),
)
sunburst.render("nested_sunburst.html")

在这个例子中,我们通过嵌套层级的方式,更好地表达了数据之间的关系。
在这里插入图片描述

高级样式与自定义

如果你需要更高级的样式和自定义,可以进一步使用Pyecharts提供的丰富功能,如渐变色、阴影效果等。

from pyecharts import options as opts
from pyecharts.charts import Sunburstdata = {"name": "root","children": [{"name": "A", "value": 10},{"name": "B", "value": 20},{"name": "C", "value": 15},{"name": "D", "value": 25},],
}sunburst = Sunburst()
sunburst.add("",data['children'],radius=[0, "90%"],color_scheme="purple",label_opts=opts.LabelOpts(formatter="{b}: {c}", position="inside"),itemstyle_opts=opts.ItemStyleOpts(border_color="white",border_width=1,opacity=0.7,shadow_blur=10,shadow_color="rgba(120, 36, 50, 0.5)",),
)
sunburst.set_global_opts(title_opts=opts.TitleOpts(title="高级样式与自定义"))
sunburst.render("advanced_sunburst.html")

在这个例子中,我们通过itemstyle_opts参数实现了边框、透明度和阴影效果的自定义。
在这里插入图片描述

进阶主题:动态旭日图

在一些场景下,我们希望展示数据的动态变化,这时候可以借助Pyecharts的Timeline组件,创建一个动态的旭日图。

from pyecharts import options as opts
from pyecharts.charts import Sunburst, Timeline# 模拟多个时间点的数据
data_timeline = [{"time": "2023-01-01","data": {"name": "root","children": [{"name": "A", "value": 15},{"name": "B", "value": 25},{"name": "C", "value": 20},{"name": "D", "value": 30},],},},# 添加更多时间点的数据...
]timeline = Timeline()for time_data in data_timeline:sunburst = Sunburst()sunburst.add("",time_data['data']['children'],radius=[0, "90%"],color_scheme="purple",label_opts=opts.LabelOpts(formatter="{b}: {c}", position="inside"),)sunburst.set_global_opts(title_opts=opts.TitleOpts(title=f"动态旭日图 - {time_data['time']}"),legend_opts=opts.LegendOpts(is_show=False),)timeline.add(sunburst, time_data['time'])timeline.render("dynamic_sunburst.html")

在这个例子中,我们使用了Timeline组件,根据不同时间点的数据绘制了一系列动态的旭日图。这是一个强大的工具,使得你可以清晰地展示数据在时间轴上的演变过程。

数据源扩展:外部JSON文件

当数据较为庞大或需要动态加载时,可以将数据存储在外部JSON文件中,并通过读取文件的方式进行数据绑定。

import json
from pyecharts import options as opts
from pyecharts.charts import Sunburst# 从外部JSON文件读取数据
with open("data.json", "r", encoding="utf-8") as f:external_data = json.load(f)sunburst = Sunburst()
sunburst.add("",external_data['children'],radius=[0, "90%"],color_scheme="purple",label_opts=opts.LabelOpts(formatter="{b}: {c}", position="inside"),
)
sunburst.set_global_opts(title_opts=opts.TitleOpts(title="外部JSON文件数据展示"),legend_opts=opts.LegendOpts(is_show=False),
)
sunburst.render("external_data_sunburst.html")

在上述代码中,我们通过json.load方法读取了外部JSON文件中的数据,然后将其传递给Sunburst图表进行绘制。

总结

通过本文,你学会了如何使用Pyecharts绘制多种炫酷的旭日图,并深入了解了各种参数的用法。无论是基本的图形绘制,还是高级的样式定制,Pyecharts都提供了强大而灵活的工具,助力你创建令人印象深刻的数据可视化图表。希望这篇文章对你在数据可视化的学习和实践中有所帮助。

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

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

相关文章

黑群晖使用SynologyDrive同步家庭和公司电脑文件

文章目录 前言一、黑群晖安装SynologyDrive服务二、樱花frp内网穿透2.1、创建一个隧道2.2、在群晖里面下载、安装、开启樱花frp 三、本地电脑安装SynologyDrive 前言 最近看b站学习视频,发现里面老师喜欢文件都是使用坚果云同步到云盘里面,以前我是瞧不…

OpenHarmony—仅允许在表达式中使用typeof运算符

规则:arkts-no-type-query 级别:错误 ArkTS仅支持在表达式中使用typeof运算符,不允许使用typeof作为类型。 TypeScript let n1 42; let s1 foo; console.log(typeof n1); // number console.log(typeof s1); // string let n2: typeof …

Nuget包缓存存放位置迁移

一、背景 默认情况下,NuGet会将项目中使用的包缓存到C盘,随着项目开发积累nuget包越来越多,这会逐渐挤占大量C盘空间,所以我们可以将nuget包缓存位置指定到其他盘中存放。 二、软件环境 win10、vs2022 三、查看当前缓存存放位…

亚信安慧AntDB打造开放创新的数据库生态

在当今信息化快速发展的时代背景下,亚信安慧AntDB作为一种新兴的DBMS,以其核心优势引起了行业内的广泛关注。它基于具有广泛全球影响力和繁荣社区支持的PostgreSQL(PG)内核,继承了PG的开放性与生态活力,同时在性能和稳定性方面进行…

【C++】引用、内联函数、auto关键字等

前言:在前面我们讲解了C入门基础的一些学习例如命名空间、缺省参数、函数重载等。今天我们将进一步的学习,跟着博主的脚步再次往前迈一步吧。 💖 博主CSDN主页:卫卫卫的个人主页 💞 👉 专栏分类:高质量C学习…

万字长文扫盲JUC基础

文章源码地址 文章目录 JUC概述什么是JUC线程和进程的概念进程和线程线程的状态wait和sleep并发和并行管程monitor用户线程与守护线程 Lock接口复习Synchronizedsyschronized卖票案例多线程编程步骤 什么是Lock接口Lock接口的介绍Lock实现可重入锁实现卖票案例 线程间通信案例…

从云计算到物联网:虚拟化技术的演变与嵌入式系统的融合

文章目录 一、硬件性能提升:摩尔定律与嵌入式虚拟化二、CPU多核技术:为嵌入式虚拟化提供支持三、业务负载整合:嵌入式虚拟化的核心需求四、降低硬件成本:虚拟化技术的经济效益五、软件重用与移植:虚拟化技术的优势六、…

【制作100个unity游戏之23】实现类似七日杀、森林一样的生存游戏4(附项目源码)

本节最终效果演示 文章目录 本节最终效果演示系列目录前言源码制作系统简单绘制制作系统面板UI斧头素材代码控制工具栏操作制作石斧 完结 系列目录 前言 欢迎来到【制作100个Unity游戏】系列!本系列将引导您一步步学习如何使用Unity开发各种类型的游戏。在这第23篇…

C#用DateTime.Now.ToString方法将日期格式化为指定格式

目录 一、DateTime.Now.ToString方法 二、实例 一、DateTime.Now.ToString方法 调用DateTime对象的ToString方法可以将当前DateTime对象的值转换为其等效的字符串表示形式,而且ToString方法提供了重载,可以在ToString方法中添加不同的参数,…

JAVA编程语言单词汇总

Java 是由 Sun Microsystems 公司于 1995 年 5 月推出的 Java 面向对象程序设计语言和 Java 平台的总称。由 James Gosling和同事们共同研发,并在 1995 年正式推出。后来 Sun 公司被 Oracle (甲骨文)公司收购,Java 也随之成为 Ora…

Android 基础技术——Bitmap

笔者希望做一个系列,整理 Android 基础技术,本章是关于 Bitmap Bitmap 内存如何计算 占用内存 宽 * 缩放比例 * 高 * 缩放比例 * 每个像素所占字节 缩放比例 设备dpi/图片所在目录的dpi Bitmap加载优化?不改变图片质量的情况下怎么优化&am…

【一竞技DOTA2】Blacklist战队官宣租借Palos参加ESL伯明翰预选赛

1、Blacklist战队官宣租借Palos参加ESL伯明翰站最终预选赛。Palos自2022年2月份以来一直效力于同为东南亚赛区的Execration战队,这次租借是替补前不久刚刚离队的Raven。 2、俄罗斯未来运动会最近官宣nouns战队因故退出。另外还有Neon、Nigma,Entity&…

【Linux】第三十九站:可重入函数、volatile、SIGCHLD信号

文章目录 一、可重入函数二、volatile三、SIGCHLD信号 一、可重入函数 如下图所示,当我们进行链表的头插的时候,我们刚刚执行完第一条语句的时候,突然收到一个信号,然后我们这个信号的自定义捕捉方法中,正好还有一个头…

“值得一试的六个浏览器扩展推荐|让你的上网更加便捷和有趣!”

iTab新标签页(免费ChatGPT) iTab是新一代组件式标签页的首创者,简洁美观高效无广,是您打造个人学习工作台的浏览器必备插件。 详情请见: iTab新标签页(免费ChatGPT) - Microsoft Edge Addons AdGuard 广告拦截器 AdGuard 广告拦截器可有效的…

GD32移植FreeRTOS+CLI过程记录

背景 之前我只在STM32F0上基于HAL库和CubeMX移植FreeRTOS,但最近发现国产化替代热潮正盛,许多项目都有国产化器件指标,而且国产单片机确实比意法的便宜,所以也买了块兆易创新的GD32F303开发板,试一试它的优劣。虽然GD…

【Web前端实操17】导航栏效果——滑动门

滑动门 定义: 类似于这种: 滑到导航栏的某一项就会出现相应的画面,里面有对应的画面出现。 箭头图标操作和引用: 像一些图标,如果需要的话,可以找字体图标,比如阿里巴巴矢量图标库:iconfont-阿里巴巴矢量图标库 选择一个——>添加至购物车——>下载代码 因…

Facebook的智能时代:AI技术在社交中的崛起

随着科技的快速发展,人工智能(AI)技术已经深刻改变了我们的生活方方面面,而社交媒体领域也不例外。在这个信息爆炸的时代,Facebook正以令人瞩目的速度推动着AI技术在社交领域的崛起。本文将深入探讨Facebook如何在智能…

STM32控制DS18B20温度传感器获取温度

时间记录:2024/1/28 一、DS18B20温度传感器介绍 (1)测温范围-55℃~125℃,在-10℃到85℃范围内误差为0.4 (2)返回的温度数据为16位二进制数据 (3)STM32和DS18B20通信使用单总线协议…

Nginx解析漏洞复现

首先这个漏洞不是软件或代码的问题,是认为疏忽造成的。 一、环境搭建 从vulhub上面下载vulhub-master.zip文件,上传到服务器中,或者直接在服务器下载。 unzip vulhub-master.zip 进入漏洞目录 cd /vulhub-master/vulhub-master/nginx/ng…

【electron】打包问题处理

目录 项目无法在win7执行场景尝试处理 项目无法在win7执行 场景 使用electron25.0.1、electron-builder24.2.1,打出来的项目在win7系统上跑不起来,报错无法定位程序输入点DiscardVirtualMemoty于动态链接库KERNEL32.dll上。 尝试处理 通过百度发现ele…