🧑 博主简介:曾任某智慧城市类企业算法总监,目前在美国市场的物流公司从事高级算法工程师一职,深耕人工智能领域,精通python数据挖掘、可视化、机器学习等,发表过AI相关的专利并多次在AI类比赛中获奖。CSDN人工智能领域的优质创作者,提供AI相关的技术咨询、项目开发和个性化解决方案等服务,如有需要请站内私信或者联系任意文章底部的的VX名片(ID:xf982831907

💬 博主粉丝群介绍:① 群内初中生、高中生、本科生、研究生、博士生遍布,可互相学习,交流困惑。② 热榜top10的常客也在群里,也有数不清的万粉大佬,可以交流写作技巧,上榜经验,涨粉秘籍。③ 群内也有职场精英,大厂大佬,可交流技术、面试、找工作的经验。④ 进群免费赠送写作秘籍一份,助你由写作小白晋升为创作大佬。⑤ 进群赠送CSDN评论防封脚本,送真活跃粉丝,助你提升文章热度。有兴趣的加文末联系方式,备注自己的CSDN昵称,拉你进群,互相学习共同进步。

在这里插入图片描述

【数据可视化-112】使用PyEcharts绘制TreeMap(矩形树图)完全指南及电商销售数据TreeMap绘制实战

    • 一、引言
    • 二、TreeMap简介
    • 三、基本TreeMap绘制
      • 3.1 简单示例
      • 3.2 数据格式详解
        • 3.2.1 扁平结构
        • 3.2.2 层次结构
    • 四、高级TreeMap示例
      • 4.1 带钻取功能的TreeMap
      • 4.2 多层级样式配置
    • 五、参数详解
      • 5.1 add() 方法参数
      • 5.2 标签配置 (LabelOpts)
      • 5.3 视觉映射配置 (VisualMapOpts)
      • 5.4 层级样式配置 (TreeMapLevelsOpts)
    • 六、完整示例与实战
    • 七、总结


一、引言

TreeMap(矩形树图)是一种流行的数据可视化方式,它通过嵌套的矩形来展示层次结构数据,每个矩形的面积大小与数据值成比例。本文将详细介绍如何使用PyEcharts库绘制TreeMap,并深入解析数据格式和各个参数的含义。

二、TreeMap简介

TreeMap是一种有效的空间填充可视化方法,特别适合展示具有层次结构的大规模数据。它能够同时显示数据的层次关系和数值大小,广泛应用于文件大小分析、市场份额展示、资源配置等领域。

三、基本TreeMap绘制

3.1 简单示例

首先,我们来看一个基本的TreeMap绘制示例:

from pyecharts import options as opts
from pyecharts.charts import TreeMap# 基本数据格式
data = [{"value": 40, "name": "类别A"},{"value": 30, "name": "类别B"},{"value": 20, "name": "name": "类别C"},{"value": 10, "name": "类别D"},
]# 创建TreeMap实例
treemap = (TreeMap().add("演示数据", data).set_global_opts(title_opts=opts.TitleOpts(title="基本TreeMap示例"))
)treemap.render("basic_treemap.html")

3.2 数据格式详解

TreeMap的数据格式可以是扁平结构或层次结构:

3.2.1 扁平结构
data = [{"value": 40, "name": "类别A"},{"value": 30, "name": "类别B"},{"value": 20, "name": "类别C"},{"value": 10, "name": "类别D"},
]
3.2.2 层次结构
data = [{"name": "类别A","value": 40,"children": [{"name": "子类A1", "value": 25},{"name": "子类A2", "value": 15},]},{"name": "类别B", "value": 30,"children": [{"name": "子类B1", "value": 20},{"name": "子类B2", "value": 10},]}
]

每个数据项可以包含以下属性:

  • name: 数据项名称
  • value: 数据项数值,决定矩形大小
  • children: 子节点数组(可选)
  • 其他自定义属性,可用于视觉映射

四、高级TreeMap示例

4.1 带钻取功能的TreeMap

下面的示例展示了如何创建带钻取功能的TreeMap,类似于Echarts官方示例,参考链接https://gallery.pyecharts.org/#/Treemap/echarts_option_query:

import re
import asyncio
from aiohttp import TCPConnector, ClientSession
import pyecharts.options as opts
from pyecharts.charts import TreeMapasync def get_json_data(url: str) -> dict:async with ClientSession(connector=TCPConnector(ssl=False)) as session:async with session.get(url=url) as response:return await response.json()# 获取官方的数据
data = asyncio.run(get_json_data(url="https://echarts.apache.org/examples/data/asset/data/""ec-option-doc-statistics-201604.json")
)tree_map_data: dict = {"children": []}def convert(source, target, base_path: str):for key in source:if base_path != "":path = base_path + "." + keyelse:path = keyif re.match(r"/^\$/", key):passelse:child = {"name": path, "children": []}target["children"].append(child)if isinstance(source[key], dict):convert(source[key], child, path)else:target["value"] = source["$count"]convert(source=data, target=tree_map_data, base_path="")(TreeMap(init_opts=opts.InitOpts(width="1200px", height="720px")).add(series_name="option",data=tree_map_data["children"],visual_min=300,leaf_depth=1,# 标签居中为 position = "inside"label_opts=opts.LabelOpts(position="inside"),).set_global_opts(legend_opts=opts.LegendOpts(is_show=False),title_opts=opts.TitleOpts(title="Echarts 配置项查询分布", subtitle="2016/04", pos_left="leafDepth"),).render("echarts_option_query.html")
)

4.2 多层级样式配置

下面的示例展示了如何为不同层级配置不同的样式,参考链接:https://gallery.pyecharts.org/#/Treemap/treemap_levels

import json
from pyecharts import options as opts
from pyecharts.charts import TreeMap# 假设我们有一个包含层次结构数据的JSON文件
# 数据格式示例:
# [
#   {
#     "name": "类别A",
#     "value": 100,
#     "children": [
#       {"name": "子类A1", "value": 60},
#       {"name": "子类A2", "value": 40}
#     ]
#   },
#   {
#     "name": "类别B", 
#     "value": 80,
#     "children": [
#       {"name": "子类B1", "value": 50},
#       {"name": "子类B2", "value": 30}
#     ]
#   }
# ]with open("treemap.json", "r", encoding="utf-8") as f:data = json.load(f)c = (TreeMap().add(series_name="演示数据",data=data,levels=[opts.TreeMapLevelsOpts(treemap_itemstyle_opts=opts.TreeMapItemStyleOpts(border_color="#555", border_width=4, gap_width=4)),opts.TreeMapLevelsOpts(color_saturation=[0.3, 0.6],treemap_itemstyle_opts=opts.TreeMapItemStyleOpts(border_color_saturation=0.7, gap_width=2, border_width=2),),opts.TreeMapLevelsOpts(color_saturation=[0.3, 0.5],treemap_itemstyle_opts=opts.TreeMapItemStyleOpts(border_color_saturation=0.6, gap_width=1),),opts.TreeMapLevelsOpts(color_saturation=[0.3, 0.5]),],).set_global_opts(title_opts=opts.TitleOpts(title="TreeMap-Levels-配置")).render("treemap_levels.html")
)

五、参数详解

5.1 add() 方法参数

.add() 方法是TreeMap的核心配置方法,主要参数包括:

  • series_name: 系列名称,用于提示框显示
  • data: 数据数组,支持扁平结构和层次结构
  • leaf_depth: 显示到第几层,默认为无限层级
  • pos_left, pos_right, pos_top, pos_bottom: TreeMap组件的位置
  • size: TreeMap组件尺寸
  • label_opts: 标签配置
  • tooltip_opts: 提示框配置
  • visual_min, visual_max: 视觉映射的最小/最大值

5.2 标签配置 (LabelOpts)

标签配置控制矩形中文本的显示方式:

label_opts=opts.LabelOpts(position="inside",  # 位置:inside, top, left, right, bottomformatter="{b}: {c}",  # 格式化器:{b}名称, {c}数值, {d}百分比color="#fff",  # 文字颜色font_size=12,  # 字体大小font_style="normal",  # 字体样式:normal, italic, obliquefont_weight="bold",  # 字体粗细:normal, bold, bolder, lighterrotate=0,  # 旋转角度margin=8,  # 边距is_show=True  # 是否显示
)

5.3 视觉映射配置 (VisualMapOpts)

视觉映射可以将数据值映射到颜色:

visual_map_opts=opts.VisualMapOpts(is_show=True,  # 是否显示视觉映射组件dimension=0,  # 指定用数据的哪个维度做映射min_=10,  # 允许的最小值max_=100,  # 允许的最大值range_color=["#313695", "#4575b4", "#74add1", "#abd9e9", "#e0f3f8", "#ffffbf", "#fee090", "#fdae61", "#f46d43", "#d73027", "#a50026"],# 颜色过渡序列is_calculable=True,  # 是否显示拖拽用的手柄orient="vertical",  # 方向:vertical, horizontalpos_left="left",  # 位置pos_top="center"  # 位置
)

5.4 层级样式配置 (TreeMapLevelsOpts)

可以为不同层级配置不同的样式:

levels=[# 第一层级样式opts.TreeMapLevelsOpts(treemap_itemstyle_opts=opts.TreeMapItemStyleOpts(border_color="#555",  # 边框颜色border_width=4,  # 边框宽度gap_width=4  # 间隙宽度)),# 第二层级样式opts.TreeMapLevelsOpts(color_saturation=[0.3, 0.6],  # 颜色饱和度范围treemap_itemstyle_opts=opts.TreeMapItemStyleOpts(border_color_saturation=0.7,  # 边框颜色饱和度gap_width=2,  # 间隙宽度border_width=2  # 边框宽度),),# 更多层级...
]

六、完整示例与实战

下面是一个完整的实战示例,展示如何使用TreeMap可视化电商销售数据:

import pandas as pd
from pyecharts import options as opts
from pyecharts.charts import TreeMap# 模拟电商销售数据(与之前相同)
data = [{"name": "电子产品","value": 10000,"children": [{"name": "手机", "value": 6000, "children": [{"name": "iPhone", "value": 3500},{"name": "三星", "value": 1500},{"name": "华为", "value": 1000}]},{"name": "电脑", "value": 3000, "children": [{"name": "笔记本", "value": 2000},{"name": "台式机", "value": 1000}]},{"name": "配件", "value": 1000, "children": [{"name": "耳机", "value": 600},{"name": "充电器", "value": 400}]}]},{"name": "服装","value": 8000,"children": [{"name": "男装", "value": 4000, "children": [{"name": "上衣", "value": 2000},{"name": "裤子", "value": 1500},{"name": "鞋", "value": 500}]},{"name": "女装", "value": 4000, "children": [{"name": "上衣", "value": 2500},{"name": "裙子", "value": 1000},{"name": "鞋", "value": 500}]}]},{"name": "家居","value": 5000,"children": [{"name": "家具", "value": 3000},{"name": "家纺", "value": 1500},{"name": "装饰", "value": 500}]}
]# 创建TreeMap(修改了VisualMapOpts的range_color)
treemap = (TreeMap(init_opts=opts.InitOpts(width="1200px", height="600px", theme="dark")).add(series_name="销售数据",data=data,levels=[opts.TreeMapLevelsOpts(treemap_itemstyle_opts=opts.TreeMapItemStyleOpts(border_color="#000", border_width=2, gap_width=3)),opts.TreeMapLevelsOpts(treemap_itemstyle_opts=opts.TreeMapItemStyleOpts(border_color="#333", border_width=1, gap_width=2)),opts.TreeMapLevelsOpts(treemap_itemstyle_opts=opts.TreeMapItemStyleOpts(border_color="#666", gap_width=1)),],label_opts=opts.LabelOpts(position="inside",formatter="{b}\n{c}",color="#fff",font_size=12),tooltip_opts=opts.TooltipOpts(formatter="{b}: {c}元")).set_global_opts(title_opts=opts.TitleOpts(title="电商销售数据分布",subtitle="按品类和子品类划分",pos_left="center",title_textstyle_opts=opts.TextStyleOpts(color="#fff"),subtitle_textstyle_opts=opts.TextStyleOpts(color="#ccc")),legend_opts=opts.LegendOpts(is_show=False),visualmap_opts=opts.VisualMapOpts(is_show=True,min_=500,max_=10000,range_color=["#FF0000", "#FF7F00", "#FFFF00",  # 红色到黄色的高对比度颜色"#00FF00", "#0000FF", "#4B0082"   # 绿色、蓝色到深紫色的高对比度颜色],orient="vertical",pos_left="10",pos_bottom="20"))
)treemap.render("ecommerce_sales_treemap_vivid.html")

七、总结

TreeMap是一种强大的数据可视化工具,特别适合展示层次结构数据和比例关系。PyEcharts提供了丰富的配置选项,可以创建高度定制化的TreeMap图表。

关键要点:

  1. TreeMap数据可以是扁平结构或层次结构
  2. 可以使用label_opts配置标签显示方式
  3. 可以使用levels参数为不同层级配置不同样式
  4. 可以使用visual_map_opts实现数据到颜色的映射
  5. TreeMap支持交互功能,如点击钻取、悬停提示等

通过合理配置这些参数,可以创建出既美观又实用的TreeMap图表,有效展示复杂的数据关系。


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

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

相关文章

Linux下编译MMCV

介绍 MMCV 有两个主要版本,mmcv 和 mmcv-lite。 mmcv 是全面版本,包含所有的特性以及丰富的开箱即用的 CUDA 算子,但构建时间较长;mmcvlite 是精简版,不包含 CUDA 算子,但拥有其他所有功能,适…

Spring Boot 分布式事务常见问题:Seata、XA 与本地消息表对比

一、前言在单体应用中,事务一般由关系型数据库本身来保证,通过 ACID 特性实现数据一致性。但随着微服务架构的普及,应用被拆分为多个独立服务,数据可能分散在不同数据库、不同存储引擎中,传统的单机事务无法再覆盖。这…

Transporter App 使用全流程详解:iOS 应用 ipa 上传工具、 uni-app 应用发布指南

在 iOS 应用开发与发布过程中,Transporter App 是苹果官方提供的一款上传工具,专门用于将 ipa 文件 或 应用资源 上传到 App Store Connect。 与 Xcode 上传 相比,Transporter 更加稳定,尤其适合大文件上传,因此在 iOS…

计算机毕业设计 基于Hadoop的B站数据分析可视化系统的设计与实现 Python 大数据毕业设计 Hadoop毕业设计选题【附源码+文档报告+安装调试】

博主介绍:✌从事软件开发10年之余,专注于Java技术领域、Python、大数据、人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ 🍅文末获取源码联系🍅 👇&…

使用自定义LLM和Embedding模型部署Vanna:基于RAG的Text-to-SQL生成

使用自定义LLM和Embedding模型部署Vanna:基于RAG的Text-to-SQL生成 说明: 首次发表日期:2024-07-12Vanna Github地址: https://github.com/vanna-ai/vannaVanna官方文档: https://vanna.ai/ 部署Vanna时我们可以选择使…

Linux多线程概念

背景知识内存管理OS进行内存管理不是以字节为单位的,而是以内存块为单位的,默认大小为4kb;系统和磁盘文件进行IO交互的单位是4kb(8个扇区);OS对内存管理实质上是对页框进行管理。页框(Page Fram…

【Problem】动态规划之跳跃游戏系列

一、跳跃游戏 55. 跳跃游戏 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/jump-game/description/?envTypeproblem-list-v2&envIddynamic-programming class Solution { public:bool canJump(vector<int>& nums) {// 状态定义&#x…

射频EVM

EVM&#xff08;Error Vector Magnitude&#xff0c;误差矢量幅度&#xff09;是衡量无线通信系统中调制质量的重要指标&#xff0c;尤其用于评估信号的调制误差和系统性能。它通常用来表示传输信号与理想信号之间的偏差&#xff0c;特别是在数字通信中。EVM的基本概念&#xf…

Java 更改 Word 文档中文本颜色

在日常的自动化文档处理中&#xff0c;我们经常会遇到需要对 Word 文档内容进行编程修改的需求&#xff0c;其中一项常见且重要的操作就是更改文本的颜色。无论是为了突出重点、统一品牌风格&#xff0c;还是实现动态内容展示&#xff0c;精准地修改文本颜色都是一个核心痛点。…

STM32—SPI协议

文章目录一、SPI 协议简介二、硬件电路2.1.SPI的连接2.2.数据的移位2.3.时序基本单元2.3.1.起始条件和终止条件2.3.2.模式 02.3.3.模式 12.3.4.模式 22.3.5.模式 32.4.时序三、软件实现四、W25Q644.1.简介4.2.硬件电路4.3.框图4.4.操作注意事项五、实验一、SPI 协议简介 SPI&a…

Qt中的QWebEngineView

第1章 本地目录结构1.1 自己写的两个网页(html)mermaid.html &#xff08;自己写的网页界面&#xff09;WebTest.html (自己写的网页界面)qwebchannel.js (Qt下载安装之后&#xff0c;会在安装目录下有这个文件&#xff0c;需要将安装目录下的改文件拷贝…

Flutter 应用国际化 (i18n) 与本地化 (l10n) 完整指南

Flutter 国际化 (i18n) 完全指南&#xff1a;从入门到精通 在现代移动应用开发中&#xff0c;支持多语言是触达全球用户的基本要求。Flutter 提供了强大且灵活的国际化 (i18n) 和本地化 (l10n) 支持。本文将带你从零开始&#xff0c;一步步深入掌握在 Flutter 中实现国际化的几…

计算机视觉与深度学习 | 计算机视觉中线特征提取与匹配算法综述

文章目录 一、线特征提取算法原理 1.1 Hough变换及其优化 1.2 LSD算法 1.3 EDLines算法 二、核心数学公式 2.1 直线表示与误差计算 2.2 LSD算法关键公式 三、线特征匹配算法 3.1 LBD描述符 3.2 匹配策略 四、代码实现 4.1 LSD线段检测(Python) 4.2 LBD特征匹配(C++) 五、算…

Transformer 模型:Attention is All You Need 的真正含义

2017 年&#xff0c;Google Brain 发布了一篇具有里程碑意义的论文——《Attention Is All You Need》&#xff0c;这篇论文不仅首次提出了 Transformer 模型&#xff0c;更重要的是&#xff0c;它宣称“注意机制&#xff08;Attention Mechanism&#xff09;就足以构建强大的模…

数据库约束表的设计

数据库约束概念&#xff1a;数据库约束是关系型数据库的一个重要功能&#xff0c;主要是保证数据的完整性&#xff0c;也可理解为数据的正确性&#xff08;数据本身是否正确&#xff0c;关联关系是否正确&#xff09;&#xff08;一般是用在指定列上&#xff09;常见的约束类型…

【案例分享】TeeChart 助力 Softdrill 提升油气钻井数据可视化能力

在钻井与地质工程领域&#xff0c;数据可视化是核心环节。图表不仅需要精确与高效&#xff0c;还需符合行业习惯并支持交互与定制。Softdrill 自 2012 年起在核心产品中集成了TeeChart 图表库&#xff0c;将复杂的井下数据转化为直观的工程图表&#xff0c;极大提升了钻井工程师…

【Flink】Flink Runtime 架构设计

Flink Runtime 架构设计 整体架构 ┌─────────────────────────────────────────────────────────────────┐ │ Flink Runtime │ ├─────────…

Git 命令教程

Git介绍 分布式版本控制系统。 Git命令 初始化/全局配置git init初始化一个Git仓库&#xff08;会创建一个.git的目录&#xff09;git config --global user.name “name”设置提交时的用户名git config user.name查看设置的用户名git config --global user.email “youemail.c…

git config --global user.name指令报错时的解决方案

问题分析 %HOMEDRIVE%%HOMEPATH%/.gitconfig 是Windows环境变量的表示方式&#xff1a; %HOMEDRIVE% 通常是 C:%HOMEPATH% 通常是 \Users\你的用户名完整路径应该是&#xff1a;C:\Users\你的用户名\.gitconfig 但这里环境变量没有被正确解析&#xff0c;显示的是字面意思。 …

websocket和socket io的区别

好的&#xff0c;这是一个更具体也更常见的问题。WebSocket 是一种协议&#xff0c;而 Socket.IO 是一个库&#xff0c;它使用了 WebSocket 但提供了多得多的功能。 简单比喻&#xff1a; WebSocket 就像是给你提供了一条高效的“快递专线”&#xff08;双向通信通道&#xff…