使用Python绘制3D堆叠条形图全解析

2025-06-25 17:50

本文主要是介绍使用Python绘制3D堆叠条形图全解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下...

在数据可视化的工具箱里,3D 图表总能带来眼前一亮的效果 —— 它突破了二维平面的限制,用立体空间展示多维度数据关系,让复杂的数据层级一目了然。今天我们要解锁的「3D 堆叠条形图」,就是一种能同时呈现类别、子类别、数值大小的强大可视化工具,特别适合展示具有分层结构的数据。无论是商业报表中的多维度业绩分析,还是科研数据中的多指标对比,它都能让你的数据呈现瞬间高级起来~

为什么选择 3D 堆叠条形图php

先聊聊这种图表的独特优势:

  • 三维空间的信息密度:x 轴和 y 轴分别代表两个独立维度(如产品类别、时间区间),z 轴通过堆叠高度展示多层数据(如不同子项的数值),单张图表可容纳传统二维图表 3 倍以上的信息。
  • 堆叠逻辑的直观性:每个基底条形代表 x-y 轴交点的整体数据,不同颜色的层叠部分清晰展示各子项的贡献度,比如 “总销售额 = 产品 A + 产品 B + 产品 C” 的结构一目了然。
  • 视觉冲击力强:立体效果让数据差异更具冲击力,配合颜色和透明度调整,即使是复杂数据集也能轻松驾驭。

适合场景举例:

  • 企业季度报告:按「地区(x 轴)- 产品(y 轴)」展示「销售额 / 成本 / 利润」的三层堆叠。
  • 学术研究:在「实验条件(x 轴)- 样本类型(y 轴)」上展示「指标 1 / 指标 2 / 指标 3」的数值对比。
  • 教育数据分析:按「年级(x 轴)- 科目(y 轴)」呈现「及格率 / 优秀率 / 平均分」的多层数据。

代码实现:从数据到 3D 世界的搭建

先奉上完整代码,我们将像拆解乐高积木一样解析每个关键模块:

import numpy as np
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D

# Generate random data
num_x = 10
num_y = 10
num_stacks = 5
data = np.random.randint(0, 10, size=(num_x, num_y, num_stacks))

# Set up figure and 3D axis
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')

x_positions = np.arange(1, num_x + 1)
y_positions = np.arange(1, num_y + 1)
dx = dy = 0.5  # width and depth of the bars

# Plot stacked bars
for i, x in enumerate(x_positions):
    for j, y in enumerate(y_positions):
        bottom = 0
        for k in range(num_stacks):
            dz = data[i, j, k]
            ax.bar3d(x, y, bottom, dx, dy, dz, alpha=0.8)
            bottom += dz

# Set labels and title
ax.set_xlabel('Variable1')
ax.set_ylabel('Variable2')
ax.set_zlabel('Variable3')
ax.set_title('3D Stacked Bar Plot')

plt.show()

使用Python绘制3D堆叠条形图全解析

核心代码逐行解析

阶段一:数据准备 —— 搭建数据立方体

num_x = 10
num_y = 10
num_stacks = 5
data = np.random.randint(0, 10, size=(num_x, num_yChina编程, num_stacks))
  • 这是用户替换数据的核心区域!当前代码生成了一个 10x10x5 的三维数组,代表:
    • x 轴有 10 个类别(num_x),比如 10 个销售区域
    • y 轴有 10 个子类别(num_y),比如 10 种产品
    • 每个 (x,y) 交点有 5 层堆叠数据(num_stacks),比如 5 个季度的指标
  • 如何替换自己的数据?
    • 如果你有现成的三维数组(形状为 [num_x, num_y, num_stacks]),直接替换data即可:
data = your_3d_data  # 例如从文件读取的numpy数组

若数据是二维表格(如 Excel 中的长表格),需要先转换为三维结构。例如,假设你的数据是:

Variable1Variable2Stack1Stack2Stack3
11532
12461
...............

可以用pandas重组数据: 

import pandas as pd
df = pd.read_csv('your_data.csv')
num_x = df['Variable1'].nunique()
num_y = df['Variable2'].nunique()
num_stacks = 3  # 假设堆叠层数为3
data = df.pivot_table(
    values=['Stack1', 'Stack2', 'Stack3'],
    index='Variable1',
    columns='Variable2'
).values.transpose(1, 0, 2)  # 调整维度顺序为(num_x, num_y, num_stacks)

阶段二:场景搭建 —— 创建 3D 画布 

  • projection='3d'是激活三维坐标轴的关键,Matplotlib 的Axes3D类会负责处理立体空间的渲染。
  • 可以通过fig.set_size_inches(10, 8)调整画布大小,数据量较大时建议增大画China编程布,避免条形过于拥挤。

阶段三:主体绘制 —— 堆叠条形的魔法循环

x_positions = np.arange(1, num_x + 1)
y_positions = np.arange(1, num_y + 1)
dx = dy = 0.5  # 条形的宽度和深度
  • x_positionsy_positions定义了每个基底条形在 x-y 平面的位置,默认从 1 开始(避免坐标 0 导致的视觉混淆)。
  • dxdy控制条形的宽度和深度(三维中的 x 和 y 方向尺寸),数值越小,条形越纤细;建议设置为小于 1 的值(如 0.8),留出条形间的间隔。
for i, x in enumerate(x_positions):
    for j, y in enumerate(y_positions):
        bottom = 0  # 堆叠基底高度初始化为0
        for k in range(num_stacks):
            dz = data[i, jpython, k]  # 第k层的高度
            ax.bar3d(x, y, bottom, dx, dy, dz, alpha=0.8)  # 绘制单层条形
            bottom += dz  # 基底高度累加上当前层高度

这是三层嵌套循环,核心逻辑是:

  • 外层循环遍历 x 轴每个类别(i 对应 x_positions 的索引)
  • 中层循环遍历 y 轴每个子类别(j 对应 y_positions 的索引)
  • 内层循环遍历每个堆叠层(k 对应 num_stacks),从基底开始逐层叠加

ax.bar3d的参数解析:

  • x, y:条形在 x-y 平面的中心坐标
  • bottom:条形底部在 z 轴的起始位置(即下层条形的顶部高度)
  • dx, dy:条形在 x 和 y 方向的宽度(建议保持一致以避免视觉变形)
  • dz:条形在 z 轴的高度(即当前层的数据值)
  • alpha=0.8:设置透明度,避免多层堆叠时颜色过深遮挡数据

细节优化

1. 颜色定制:给每层条形穿上不同的 “外衣”

当前代码使用默认颜色,可能导致多层堆叠时难以区分。可以通过color参数自定义每层颜色:

# 定义每层的颜色(建议使用明度差异大的颜色)
stack_colors = ['#FF5733', '#33FF57', '#3357FF', '#FF33F7', '#F7FF33']

# 在绘制时传入颜色
ax.bar3d(x, y, bottom, dx, dy, dz, color=stack_colors[k], alpha=0.8)

2. 坐标轴优化:让标签清晰易读 

ax.set_xticks(x_positions)  # 设置x轴刻度为实际位置
ax.set_yticks(y_positions)  # 设置y轴刻度为实际位置
ax.tick_params(axis='x', labelsize=8, rotation=15)  # 旋转x轴标签避免重叠
ax.tick_params(axis='y', labelsize=8, rotation=10)  # 微调y轴标签角度

3. 视角调整:找到最佳观察角度 

ax.view_init(elev=30, azim=45)  # elev:仰角,azim:方位角
# 常用组合:
# 正前方视角:elev=90, azim=0
# 俯视视角:elev=60, azim=30

4. 添加数据标签:让数值一目了然(进阶) 

for i, x in enumerate(x_positions):
    for j, y in enumerate(y_positions):
        bottom = 0
        for k in range(num_stacks):
            dz = data[i, j, k]
            # 计算条形顶部中心坐标
            x_center = x + dx/2
            y_center = y + dy/2
            z_top = bottom + dz/2
            ax.text(x_center, y_center, z_top, f'{dz}', ha='center', va='center')
            bottom += dz

5. 背景与网格:提升视觉舒适度 

ax.grid(False)  # 关闭默认网格,避免干扰
ax.xaxis.set_pane_color((1.0, 1.0, 1.0, 0.0))  # 透明化坐标轴背景
ax.yaxis.set_pane_color((1.0, 1.0, 1.0, 0.0))
ax.zaxis.set_pane_color((1.0, 1.0, 1.0, 0.0))

应用场景:3D 堆叠图的实战案例

China编程

案例 1:电商平台多维度销售分析

  • x 轴:省份(10 个地区)
  • y 轴:产品类别(10 种商品)
  • 堆叠层:销售额、成本、利润、订单量、退货量(5 层数据)
    通过颜色区分各层,能快速定位 “高销售额但高退货” 的异常区域,或 “低成本高利润” 的明星产品组合。

案例 2:气候数据多指标对比

  • x 轴:月份(12 个月)
  • y 轴:城市(5 个代表城市)
  • 堆叠层:降水量、平均气温、湿度、风速、日照时长(5 层数据)
    立体展示让不同城市的气候特征对比更直观,比如 “某城市夏季降水量远高于其他城市” 的模式一目了然。

案例 3:教育领域学生表现分析

  • x 轴:学科(语文、数学、英语等 8 科)
  • y 轴:班级(6 个班级)
  • 堆叠层:平均分、优秀率、及格率、低分率、缺考率(5 层数据)
    帮助教育管理者快速发现 “某班级数学及格率低但优秀率高” 的两极分化现象,或 “某学科全年级缺考率异常” 的问题。

避坑指南:3D 图表的常见问题与解决方案

数据遮挡问题

  • 现象:上层条形遮挡下层数据,尤其是堆叠层数多或透明度低时。
  • 解决方案:
    • 增加透明度(alpha=0.6
    • 调整视角,让上层条形 “倾斜” 露出下层(通过view_init设置仰角和方位角)
    • 减少堆叠层数(建议不超过 6 层,超过后信息会过载)

性能卡顿

  • 现象:数据量过大(如 20x20x10)时,绘图速度变慢。
  • 解决方案:
    • 简化数据:对稀疏数据进行聚合(如求平均值)
    • 降低图形复杂度:减小dx/dy值,或关闭不必要的网格和背景渲染

颜色混淆

  • 现象:相近颜色的堆叠层难以区分。
  • 解决方案:
    • 使用色盲友好调色板(如plt.cm.tab10
    • 在每层条形顶部添加数据标签(见前文代码)
    • 在图例中说明各层颜色对应的含义(需额外编写图例代码)

进阶玩法:让 3D 图表更动态

1. 交互式旋转与缩放

Matplotlib 默认支持鼠标交互:

左键拖动:旋转视角

右键拖动:平移画布

滚轮:缩放视图

配合plt.ion()(交互模式),可以在 Jupyter Notebook 中实时调整视角。

2. 动画效果(生成 GIF)

from matplotlib.animation import FuncAnimation

def update(frame):
    ax.view_init(elev=30, azim=frame)  # 动态改变方位角
    return fig,

ani = FuncAnimation(fig, update, frames=np.linspace(0, 360, 30), repeat=True)
ani.save('3d_bar_animation.gif', writer='pillow')

3. 与其他图表结合

将 3D 堆叠图与 2D 趋势图组合,形成多视图仪表盘:

fig, (ax3d, ax2d) = plt.subplots(1, 2, figsize=(15, 6), subplot_kw={'projection': '3d'})
# 在ax3d绘制堆叠图,在ax2d绘制x轴总和的折线图

结语:让数据在三维空间中舞动

3D 堆叠条形图就像一个数据舞台,每个条形都是舞台上的舞者,用高度和颜色演绎数据的故事。通过今天的教程,你已经掌握了从数据准备到细节优化的全流程,现在只差替换成你自己的数据啦!

替换数据的关键步骤回顾:

  • 确保你的数据是三维数组,形状为[num_x, num_y, num_stacks]
  • 替换代码中data = np.random.randint(...)这一行,直接赋值为你的数据
  • 根据数据含义修改坐标轴标签(set_xlabel/set_ylabel/set_zlabel)和标题

快去试试吧!无论是分析商业数据还是科研成果,这种立体可视化方式都会让你的报告瞬间提升一个档次~

到此这篇关于使用python绘制3D堆叠条形图全解析的文章就介绍到这了,更多相关Python绘制3D堆叠条形图内容请搜索编程China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于使用Python绘制3D堆叠条形图全解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155213

相关文章

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

深度解析Python装饰器常见用法与进阶技巧

《深度解析Python装饰器常见用法与进阶技巧》Python装饰器(Decorator)是提升代码可读性与复用性的强大工具,本文将深入解析Python装饰器的原理,常见用法,进阶技巧与最佳实践,希望可... 目录装饰器的基本原理函数装饰器的常见用法带参数的装饰器类装饰器与方法装饰器装饰器的嵌套与组合进阶技巧

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

深度解析Spring Boot拦截器Interceptor与过滤器Filter的区别与实战指南

《深度解析SpringBoot拦截器Interceptor与过滤器Filter的区别与实战指南》本文深度解析SpringBoot中拦截器与过滤器的区别,涵盖执行顺序、依赖关系、异常处理等核心差异,并... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编