当前位置: 首页 > news >正文

Pyecharts绘制多种炫酷气泡图

Pyecharts绘制多种炫酷气泡图

引言

数据可视化是数据分析中不可或缺的一环,而Pyecharts作为一款基于Echarts的Python图表库,提供了丰富的图表类型,其中气泡图是一种常用于展示三维数据的炫酷图表。本文将介绍如何使用Pyecharts绘制多种炫酷气泡图,并对各种参数进行详细说明,帮助读者更好地理解和定制气泡图。

准备工作

首先,确保你已经安装了Pyecharts库:

pip install pyecharts

然后,我们准备一些示例数据,这里以某公司销售数据为例。

import random# 生成示例数据
data = [(i, random.randint(50, 200), random.randint(1, 100)) for i in range(1, 11)]

基础气泡图

首先,我们来绘制一个基础的气泡图。

from pyecharts import options as opts
from pyecharts.charts import Scatter# 绘制基础气泡图
scatter_basic = Scatter()
scatter_basic.add_xaxis([str(item[0]) for item in data])
scatter_basic.add_yaxis("销售额", [item[1] for item in data],symbol_size=[item[2] for item in data],label_opts=opts.LabelOpts(is_show=False))
scatter_basic.set_global_opts(title_opts=opts.TitleOpts(title="基础气泡图"),xaxis_opts=opts.AxisOpts(type_="category"))# 渲染图表
scatter_basic.render("basic_bubble_chart.html")

在这个基础气泡图中,我们使用了Scatter类,通过add_xaxisadd_yaxis方法添加横纵坐标数据。symbol_size参数表示气泡的大小,这里使用了销售量作为气泡的大小。label_opts参数用于控制标签的显示,这里我们将标签关闭。
在这里插入图片描述

自定义气泡图

接下来,我们将进一步自定义气泡图,包括颜色、透明度等。

from pyecharts import options as opts
from pyecharts.charts import Scatter# 绘制自定义气泡图
scatter_custom = Scatter()
scatter_custom.add_xaxis([str(item[0]) for item in data])
scatter_custom.add_yaxis("销售额", [item[1] for item in data],symbol_size=[item[2] for item in data],label_opts=opts.LabelOpts(is_show=False),itemstyle_opts=opts.ItemStyleOpts(color="skyblue", opacity=0.8))
scatter_custom.set_global_opts(title_opts=opts.TitleOpts(title="自定义气泡图"),xaxis_opts=opts.AxisOpts(type_="category"))# 渲染图表
scatter_custom.render("custom_bubble_chart.html")

在这个自定义气泡图中,我们通过itemstyle_opts参数设置了气泡的颜色和透明度。这里我们将颜色设置为天蓝色,透明度设置为0.8。

多系列气泡图

有时候,我们需要在同一张图上展示多组数据,这时可以使用多系列气泡图。

from pyecharts import options as opts
from pyecharts.charts import Scatter# 生成示例数据
data2 = [(i, random.randint(30, 150), random.randint(1, 100)) for i in range(1, 11)]# 绘制多系列气泡图
scatter_multi_series = Scatter()
scatter_multi_series.add_xaxis([str(item[0]) for item in data])
scatter_multi_series.add_yaxis("销售A", [item[1] for item in data],symbol_size=[item[2] for item in data],label_opts=opts.LabelOpts(is_show=False))
scatter_multi_series.add_yaxis("销售B", [item[1] for item in data2],symbol_size=[item[2] for item in data2],label_opts=opts.LabelOpts(is_show=False))
scatter_multi_series.set_global_opts(title_opts=opts.TitleOpts(title="多系列气泡图"),xaxis_opts=opts.AxisOpts(type_="category"))# 渲染图表
scatter_multi_series.render("multi_series_bubble_chart.html")

在多系列气泡图中,我们通过多次调用add_yaxis方法添加不同系列的数据。
在这里插入图片描述

气泡图标签和工具箱

除了基础的气泡图外,Pyecharts还支持对气泡图的标签和工具箱进行定制。

from pyecharts import options as opts
from pyecharts.charts import Scatter# 绘制带标签的气泡图
scatter_with_label = Scatter()
scatter_with_label.add_xaxis([str(item[0]) for item in data])
scatter_with_label.add_yaxis("销售额", [item[1] for item in data],symbol_size=[item[2] for item in data],label_opts=opts.LabelOpts(is_show=True, position="top"))
scatter_with_label.set_global_opts(title_opts=opts.TitleOpts(title="带标签的气泡图"),xaxis_opts=opts.AxisOpts(type_="category"))# 渲染图表
scatter_with_label.render("bubble_chart_with_label.html")

在这个带标签的气泡图中,我们通过label_opts参数开启了标签的显示,并设置标签位置为顶部。

接下来,我们将为气泡图添加工具箱,使用户可以更灵活地交互。

from pyecharts import options as opts
from pyecharts.charts import Scatter
from pyecharts.commons.utils import JsCode# 绘制带工具箱的气泡图
scatter_with_toolbox = Scatter()
scatter_with_toolbox.add_xaxis([str(item[0]) for item in data])
scatter_with_toolbox.add_yaxis("销售额", [item[1] for item in data],symbol_size=[item[2] for item in data],label_opts=opts.LabelOpts(is_show=False))
scatter_with_toolbox.set_global_opts(title_opts=opts.TitleOpts(title="带工具箱的气泡图"),xaxis_opts=opts.AxisOpts(type_="category"),toolbox_opts=opts.ToolboxOpts(feature={"saveAsImage": {"title": "保存图片"},"dataZoom": {"title": {"zoom": "区域缩放", "back": "区域缩放还原"}},}),
)# 渲染图表
scatter_with_toolbox.render("bubble_chart_with_toolbox.html")

在这个带工具箱的气泡图中,我们通过toolbox_opts参数添加了两个功能按钮,一个用于保存图片,另一个用于区域缩放。

动态气泡图

最后,我们介绍如何制作一个动态气泡图,通过时间轴展示数据的变化。

from pyecharts import options as opts
from pyecharts.charts import Scatter, Timeline# 生成示例数据
timeline_data = {f"2022-{i}": [(i, random.randint(50, 200), random.randint(1, 100)) for i in range(1, 11)] for i in range(1, 13)
}# 绘制动态气泡图
timeline_scatter = Timeline()
for year_month, data in timeline_data.items():scatter = Scatter()scatter.add_xaxis([str(item[0]) for item in data])scatter.add_yaxis("销售额", [item[1] for item in data],symbol_size=[item[2] for item in data],label_opts=opts.LabelOpts(is_show=False))scatter.set_global_opts(title_opts=opts.TitleOpts(title=f"{year_month} 动态气泡图"),xaxis_opts=opts.AxisOpts(type_="category"),)timeline_scatter.add(scatter, year_month)# 渲染图表
timeline_scatter.render("dynamic_bubble_chart.html")

在动态气泡图中,我们使用了Timeline类,并通过循环逐步添加各个时间点的气泡图,从而实现动态效果。

高级气泡图定制

除了上述介绍的基础和进阶功能之外,Pyecharts还提供了一些高级的定制选项,让气泡图更加炫酷。

渐变颜色气泡图

有时候,我们希望气泡的颜色能够根据数据的大小变化而渐变,以更直观地反映数值差异。

from pyecharts import options as opts
from pyecharts.charts import Scatter
from pyecharts.commons.utils import JsCode# 绘制渐变颜色气泡图
scatter_gradient_color = Scatter()
scatter_gradient_color.add_xaxis([str(item[0]) for item in data])
scatter_gradient_color.add_yaxis("销售额", [item[1] for item in data],symbol_size=[item[2] for item in data],label_opts=opts.LabelOpts(is_show=False),itemstyle_opts=opts.ItemStyleOpts(color=JsCode("""new echarts.graphic.RadialGradient(0.4, 0.3, 1, [{offset: 0,color: 'rgba(0, 255, 255, 0.7)'}, {offset: 1,color: 'rgba(0, 255, 255, 0.3)'}])""")))
scatter_gradient_color.set_global_opts(title_opts=opts.TitleOpts(title="渐变颜色气泡图"),xaxis_opts=opts.AxisOpts(type_="category"))# 渲染图表
scatter_gradient_color.render("gradient_color_bubble_chart.html")

在这个渐变颜色气泡图中,我们通过itemstyle_opts参数使用JsCode设置了颜色为渐变效果。
在这里插入图片描述

3D气泡图

为了展示更加立体的气泡图,Pyecharts也支持绘制3D气泡图。

from pyecharts import options as opts
from pyecharts.charts import Scatter3D# 绘制3D气泡图
scatter_3d = Scatter3D()
scatter_3d.add("", [(item[0], item[1], item[2]) for item in data],grid3d_opts=opts.Grid3DOpts(width=100, height=100, depth=100),label_opts=opts.LabelOpts(is_show=False),itemstyle_opts=opts.ItemStyleOpts(color="skyblue", opacity=0.8))
scatter_3d.set_global_opts(title_opts=opts.TitleOpts(title="3D气泡图"))# 渲染图表
scatter_3d.render("3d_bubble_chart.html")

在3D气泡图中,我们使用了Scatter3D类,并通过grid3d_opts参数设置了三维坐标系的网格大小。
在这里插入图片描述

结语

通过本文的介绍,读者可以更全面地了解如何使用Pyecharts绘制各种炫酷气泡图,包括标签、工具箱、动态效果以及一些高级的定制选项。希望本文能够帮助读者在实际项目中更灵活地运用Pyecharts进行数据可视化,使得分析结果更加生动有趣。

相关文章:

Pyecharts绘制多种炫酷气泡图

Pyecharts绘制多种炫酷气泡图 引言 数据可视化是数据分析中不可或缺的一环,而Pyecharts作为一款基于Echarts的Python图表库,提供了丰富的图表类型,其中气泡图是一种常用于展示三维数据的炫酷图表。本文将介绍如何使用Pyecharts绘制多种炫酷…...

C# 多线程(2)——线程同步

目录 1 线程不安全2 线程同步方式2.1 简单的阻塞方法2.2 锁2.2.1 Lock使用2.2.2 互斥体Mutex2.2.3 信号量Semaphore2.2.3 轻量级信号量SemaphoreSlim2.2.4 读写锁ReaderWriterLockSlim 2.3 信号同步2.3.1 AutoResetEvent2.3.1.1 AutoResetEvent实现双向信号 2.3.2 ManualResetE…...

Java设计模式【工厂模式】

Java设计模式【工厂模式】 前言 三种工厂模式:简单工厂模式、工厂方法模式、抽象工厂模式; 创建型设计模式封装对象的创建过程,将对象的创建和使用分离开,从而提高代码的可维护性和可扩展性 简单工厂模式 概述:将…...

AI智能分析+明厨亮灶智慧管理平台助力“舌尖上的安全”

春节是中国最重要的传统节日之一,在春节期间,人们聚餐需求激增,餐饮业也迎来了高峰期。在这个时期,餐饮企业需要更加注重食品安全和卫生质量,以保证消费者的健康和权益,明厨亮灶智慧管理成为了餐饮业中备受…...

【现代密码学基础】详解完美安全与香农定理

目录 一. 介绍 二. 完美安全的密钥与消息空间 三. 完美安全的密钥长度 四. 最优的完美安全方案 五. 香农定理 (1)理论分析 (2)严格的正向证明 (3)严格的反向证明 六. 小结 一. 介绍 一次一密方案…...

Python 将文本转换成语音播放 pyttsx3

Python 将文本转换成语音播放 pyttsx3 目录 Python 将文本转换成语音播放 pyttsx3 1. 安装 2. 使用 3. 封装 Pyttsx3 是一个 Python 库,它提供了文本到语音(Text-to-Speech,TTS)转换的功能。这个库允许 Python 程序通过调用本…...

FPGA高端项目:Xilinx Artix7系列FPGA 多路视频缩放拼接 工程解决方案 提供4套工程源码+技术支持

目录 1、前言版本更新说明给读者的一封信FPGA就业高端项目培训计划免责声明 2、相关方案推荐我这里已有的FPGA图像缩放方案我已有的FPGA视频拼接叠加融合方案本方案的Xilinx Kintex7系列FPGA上的ov5640版本本方案的Xilinx Kintex7系列FPGA上的HDMI版本 3、设计思路框架设计框图…...

开源模型应用落地-业务优化篇(三)

一、前言 假如您跟随我的脚步,学习到上一篇的内容,到这里,相信细心的您,已经发现了,在上一篇中遗留的问题。那就是IM服务过载的时候,如何进行水平扩容? 因为在每个IM服务中,我们用JV…...

基于SpringBoot+Vue实现的物流快递仓库管理系统

基于SpringBootVue实现的物流快递仓库管理系统 文章目录 基于SpringBootVue实现的物流快递仓库管理系统系统介绍技术选型成果展示账号地址及其他说明源码获取 系统介绍 系统演示 关注视频号【全栈小白】,观看演示视频 基于SpringBootVue实现的物流快递仓库管理系…...

编程笔记 html5cssjs 072 JavaScrip BigInt数据类型

编程笔记 html5&css&js 072 JavaScrip BigInt数据类型 一、BigInt 数据类型二、BigInt 的创建和使用三、BigInt 操作与方法三、示例小结 JavaScript BigInt 数据类型是一种内置的数据类型,用于表示大于 Number.MAX_SAFE_INTEGER(即2^53 - 1&…...

matlab simulink 步进电机控制

1、内容简介 略 41-可以交流、咨询、答疑 2、内容说明 电动执行器定位控制在生产生活中具有广泛的应用,在使用搭载步进电机的电动执行器进行定位控制的时候,定位系统的定位精度和响应波形,会随着负载质量的变化而变化,这是由电…...

使用阿里云的IDaaS实现知行之桥EDI系统的单点登录

,在开始测试之前,需要确定用哪个信息作为“登陆用户的ID字段”。 这个字段用来在完成SSO登陆之后,用哪个信息将阿里云IDaaS的用户和知行之桥EDI系统的用户做对应。这里我们使用了 phonenumber 这个自定义属性。需要在阿里云做如下配置&#x…...

基于微服务的高考志愿智能辅助决策系统(附源码)

目录 一.引言 1、编写目的 2、系统功能概述 二.功能分析 三.微服务模块 1、微服务用户相关模块 (1)用户注册 (2)用户登录 (3)用户信息管理 (4)用户操作 2、微服务文件云存…...

LeetCode —— 137. 只出现一次的数字 II

😶‍🌫️😶‍🌫️😶‍🌫️😶‍🌫️Take your time ! 😶‍🌫️😶‍🌫️😶‍🌫️😶‍🌫️…...

pnpm、npm、yarn 包管理工具

1、npm 关键词:软件包管理器、命令行工具、一个社区和一个平台 npm(Node Package Manager)是一个用于Node.js环境的软件包管理器。它是一个命令行工具,用于安装、升级、删除和管理JavaScript软件包。npm最初是随同Node.js一起发布…...

微服务知识

1、概念 大型单体应用拆分成多个独立部署运行的微服务(解决并发问题)​​​​​​​ 2、特点 3、技术栈 4、微服务带来的问题 ​​​​​​​ 5、微服务的注册中心 服务注册与发现:微服务实例在启动时会向注册中心注册自己的信息&#xf…...

如何在微信搭建私域流量池?

A: ①给客户打标签 添加标签,多维度构建用户画像,精准发送消息。 ②群发信息 选择自定义时间,上传内容 (支持文字,图片) ,一键群发 。 ③建立专属素材库 将常用的话术、图片与文件录入至素材库,员工可随…...

MySQL原理(三)锁定机制(1)综述

一、介绍: 1、锁的本质 业务场景中存在共享资源,多个进程或线程需要竞争获取并处理共享资源,为了保证公平、可靠、结果正确等业务逻辑,要把并发执行的问题变为串行,串行时引入第三方锁当成谁有权限来操作共享资源的判…...

Qt知识点总结

将枚举类型转换为字符串 这里使用的在网络编程中&#xff0c;获取socket状态并显示的时候&#xff0c;遇到的一个问题 #include <QMetaEnum>// 将枚举类型转换为字符串 QMetaEnum metaEnum QMetaEnum::fromType<QAbstractSocket::SocketState>(); const char *c…...

什么是系统工程(字幕)13

0 00:00:00,670 --> 00:00:01,582 如果不加图 1 00:00:01,582 --> 00:00:02,130 怎么加 2 00:00:02,130 --> 00:00:03,225 我们来看一下 3 00:00:03,225 --> 00:00:03,590 你看 4 00:00:03,980 --> 00:00:06,720 右键点这个&#xff0c;添加元素 5 00:00:0…...

基于算法竞赛的c++编程(28)结构体的进阶应用

结构体的嵌套与复杂数据组织 在C中&#xff0c;结构体可以嵌套使用&#xff0c;形成更复杂的数据结构。例如&#xff0c;可以通过嵌套结构体描述多层级数据关系&#xff1a; struct Address {string city;string street;int zipCode; };struct Employee {string name;int id;…...

Mac软件卸载指南,简单易懂!

刚和Adobe分手&#xff0c;它却总在Library里给你写"回忆录"&#xff1f;卸载的Final Cut Pro像电子幽灵般阴魂不散&#xff1f;总是会有残留文件&#xff0c;别慌&#xff01;这份Mac软件卸载指南&#xff0c;将用最硬核的方式教你"数字分手术"&#xff0…...

安卓基础(aar)

重新设置java21的环境&#xff0c;临时设置 $env:JAVA_HOME "D:\Android Studio\jbr" 查看当前环境变量 JAVA_HOME 的值 echo $env:JAVA_HOME 构建ARR文件 ./gradlew :private-lib:assembleRelease 目录是这样的&#xff1a; MyApp/ ├── app/ …...

排序算法总结(C++)

目录 一、稳定性二、排序算法选择、冒泡、插入排序归并排序随机快速排序堆排序基数排序计数排序 三、总结 一、稳定性 排序算法的稳定性是指&#xff1a;同样大小的样本 **&#xff08;同样大小的数据&#xff09;**在排序之后不会改变原始的相对次序。 稳定性对基础类型对象…...

Mysql8 忘记密码重置,以及问题解决

1.使用免密登录 找到配置MySQL文件&#xff0c;我的文件路径是/etc/mysql/my.cnf&#xff0c;有的人的是/etc/mysql/mysql.cnf 在里最后加入 skip-grant-tables重启MySQL服务 service mysql restartShutting down MySQL… SUCCESS! Starting MySQL… SUCCESS! 重启成功 2.登…...

Ubuntu Cursor升级成v1.0

0. 当前版本低 使用当前 Cursor v0.50时 GitHub Copilot Chat 打不开&#xff0c;快捷键也不好用&#xff0c;当看到 Cursor 升级后&#xff0c;还是蛮高兴的 1. 下载 Cursor 下载地址&#xff1a;https://www.cursor.com/cn/downloads 点击下载 Linux (x64) &#xff0c;…...

在树莓派上添加音频输入设备的几种方法

在树莓派上添加音频输入设备可以通过以下步骤完成&#xff0c;具体方法取决于设备类型&#xff08;如USB麦克风、3.5mm接口麦克风或HDMI音频输入&#xff09;。以下是详细指南&#xff1a; 1. 连接音频输入设备 USB麦克风/声卡&#xff1a;直接插入树莓派的USB接口。3.5mm麦克…...

【WebSocket】SpringBoot项目中使用WebSocket

1. 导入坐标 如果springboot父工程没有加入websocket的起步依赖&#xff0c;添加它的坐标的时候需要带上版本号。 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId> </dep…...

快速排序算法改进:随机快排-荷兰国旗划分详解

随机快速排序-荷兰国旗划分算法详解 一、基础知识回顾1.1 快速排序简介1.2 荷兰国旗问题 二、随机快排 - 荷兰国旗划分原理2.1 随机化枢轴选择2.2 荷兰国旗划分过程2.3 结合随机快排与荷兰国旗划分 三、代码实现3.1 Python实现3.2 Java实现3.3 C实现 四、性能分析4.1 时间复杂度…...

CSS3相关知识点

CSS3相关知识点 CSS3私有前缀私有前缀私有前缀存在的意义常见浏览器的私有前缀 CSS3基本语法CSS3 新增长度单位CSS3 新增颜色设置方式CSS3 新增选择器CSS3 新增盒模型相关属性box-sizing 怪异盒模型resize调整盒子大小box-shadow 盒子阴影opacity 不透明度 CSS3 新增背景属性ba…...