【數據可視化-112】使用PyEcharts繪制TreeMap(矩形樹圖)完全指南及電商銷售數據TreeMap繪制實戰

🧑 博主簡介:曾任某智慧城市類企業算法總監,目前在美國市場的物流公司從事高級算法工程師一職,深耕人工智能領域,精通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…