亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用Python繪制3D堆疊條形圖全解析

 更新時間:2025年06月25日 15:00:58   作者:Code_Verse  
在數(shù)據(jù)可視化的工具箱里,3D 圖表總能帶來眼前一亮的效果,本文就來和大家聊聊如何使用Python實現(xiàn)繪制3D 堆疊條形圖,感興趣的小伙伴可以了解下

在數(shù)據(jù)可視化的工具箱里,3D 圖表總能帶來眼前一亮的效果 —— 它突破了二維平面的限制,用立體空間展示多維度數(shù)據(jù)關系,讓復雜的數(shù)據(jù)層級一目了然。今天我們要解鎖的「3D 堆疊條形圖」,就是一種能同時呈現(xiàn)類別、子類別、數(shù)值大小的強大可視化工具,特別適合展示具有分層結構的數(shù)據(jù)。無論是商業(yè)報表中的多維度業(yè)績分析,還是科研數(shù)據(jù)中的多指標對比,它都能讓你的數(shù)據(jù)呈現(xiàn)瞬間高級起來~

為什么選擇 3D 堆疊條形圖

先聊聊這種圖表的獨特優(yōu)勢:

  • 三維空間的信息密度:x 軸和 y 軸分別代表兩個獨立維度(如產(chǎn)品類別、時間區(qū)間),z 軸通過堆疊高度展示多層數(shù)據(jù)(如不同子項的數(shù)值),單張圖表可容納傳統(tǒng)二維圖表 3 倍以上的信息。
  • 堆疊邏輯的直觀性:每個基底條形代表 x-y 軸交點的整體數(shù)據(jù),不同顏色的層疊部分清晰展示各子項的貢獻度,比如 “總銷售額 = 產(chǎn)品 A + 產(chǎn)品 B + 產(chǎn)品 C” 的結構一目了然。
  • 視覺沖擊力強:立體效果讓數(shù)據(jù)差異更具沖擊力,配合顏色和透明度調整,即使是復雜數(shù)據(jù)集也能輕松駕馭。

適合場景舉例:

  • 企業(yè)季度報告:按「地區(qū)(x 軸)- 產(chǎn)品(y 軸)」展示「銷售額 / 成本 / 利潤」的三層堆疊。
  • 學術研究:在「實驗條件(x 軸)- 樣本類型(y 軸)」上展示「指標 1 / 指標 2 / 指標 3」的數(shù)值對比。
  • 教育數(shù)據(jù)分析:按「年級(x 軸)- 科目(y 軸)」呈現(xiàn)「及格率 / 優(yōu)秀率 / 平均分」的多層數(shù)據(jù)。

代碼實現(xiàn):從數(shù)據(jù)到 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()

核心代碼逐行解析

階段一:數(shù)據(jù)準備 —— 搭建數(shù)據(jù)立方體

num_x = 10
num_y = 10
num_stacks = 5
data = np.random.randint(0, 10, size=(num_x, num_y, num_stacks))
  • 這是用戶替換數(shù)據(jù)的核心區(qū)域!當前代碼生成了一個 10x10x5 的三維數(shù)組,代表:
    • x 軸有 10 個類別(num_x),比如 10 個銷售區(qū)域
    • y 軸有 10 個子類別(num_y),比如 10 種產(chǎn)品
    • 每個 (x,y) 交點有 5 層堆疊數(shù)據(jù)(num_stacks),比如 5 個季度的指標
  • 如何替換自己的數(shù)據(jù)?
    • 如果你有現(xiàn)成的三維數(shù)組(形狀為 [num_x, num_y, num_stacks]),直接替換data即可:
data = your_3d_data  # 例如從文件讀取的numpy數(shù)組

若數(shù)據(jù)是二維表格(如 Excel 中的長表格),需要先轉換為三維結構。例如,假設你的數(shù)據(jù)是:

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

可以用pandas重組數(shù)據(jù): 

import pandas as pd
df = pd.read_csv('your_data.csv')
num_x = df['Variable1'].nunique()
num_y = df['Variable2'].nunique()
num_stacks = 3  # 假設堆疊層數(shù)為3
data = df.pivot_table(
    values=['Stack1', 'Stack2', 'Stack3'],
    index='Variable1',
    columns='Variable2'
).values.transpose(1, 0, 2)  # 調整維度順序為(num_x, num_y, num_stacks)

階段二:場景搭建 —— 創(chuàng)建 3D 畫布 

  • projection='3d'是激活三維坐標軸的關鍵,Matplotlib 的Axes3D類會負責處理立體空間的渲染。
  • 可以通過fig.set_size_inches(10, 8)調整畫布大小,數(shù)據(jù)量較大時建議增大畫布,避免條形過于擁擠。

階段三:主體繪制 —— 堆疊條形的魔法循環(huán)

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 方向尺寸),數(shù)值越小,條形越纖細;建議設置為小于 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, j, k]  # 第k層的高度
            ax.bar3d(x, y, bottom, dx, dy, dz, alpha=0.8)  # 繪制單層條形
            bottom += dz  # 基底高度累加上當前層高度

這是三層嵌套循環(huán),核心邏輯是:

  • 外層循環(huán)遍歷 x 軸每個類別(i 對應 x_positions 的索引)
  • 中層循環(huán)遍歷 y 軸每個子類別(j 對應 y_positions 的索引)
  • 內(nèi)層循環(huán)遍歷每個堆疊層(k 對應 num_stacks),從基底開始逐層疊加

ax.bar3d的參數(shù)解析:

  • x, y:條形在 x-y 平面的中心坐標
  • bottom:條形底部在 z 軸的起始位置(即下層條形的頂部高度)
  • dx, dy:條形在 x 和 y 方向的寬度(建議保持一致以避免視覺變形)
  • dz:條形在 z 軸的高度(即當前層的數(shù)據(jù)值)
  • alpha=0.8:設置透明度,避免多層堆疊時顏色過深遮擋數(shù)據(jù)

細節(jié)優(yōu)化

1. 顏色定制:給每層條形穿上不同的 “外衣”

當前代碼使用默認顏色,可能導致多層堆疊時難以區(qū)分??梢酝ㄟ^color參數(shù)自定義每層顏色:

# 定義每層的顏色(建議使用明度差異大的顏色)
stack_colors = ['#FF5733', '#33FF57', '#3357FF', '#FF33F7', '#F7FF33']

# 在繪制時傳入顏色
ax.bar3d(x, y, bottom, dx, dy, dz, color=stack_colors[k], alpha=0.8)

2. 坐標軸優(yōu)化:讓標簽清晰易讀 

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. 添加數(shù)據(jù)標簽:讓數(shù)值一目了然(進階) 

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. 背景與網(wǎng)格:提升視覺舒適度 

ax.grid(False)  # 關閉默認網(wǎng)格,避免干擾
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 堆疊圖的實戰(zhàn)案例

案例 1:電商平臺多維度銷售分析

  • x 軸:省份(10 個地區(qū))
  • y 軸:產(chǎn)品類別(10 種商品)
  • 堆疊層:銷售額、成本、利潤、訂單量、退貨量(5 層數(shù)據(jù))
    通過顏色區(qū)分各層,能快速定位 “高銷售額但高退貨” 的異常區(qū)域,或 “低成本高利潤” 的明星產(chǎn)品組合。

案例 2:氣候數(shù)據(jù)多指標對比

  • x 軸:月份(12 個月)
  • y 軸:城市(5 個代表城市)
  • 堆疊層:降水量、平均氣溫、濕度、風速、日照時長(5 層數(shù)據(jù))
    立體展示讓不同城市的氣候特征對比更直觀,比如 “某城市夏季降水量遠高于其他城市” 的模式一目了然。

案例 3:教育領域學生表現(xiàn)分析

  • x 軸:學科(語文、數(shù)學、英語等 8 科)
  • y 軸:班級(6 個班級)
  • 堆疊層:平均分、優(yōu)秀率、及格率、低分率、缺考率(5 層數(shù)據(jù))
    幫助教育管理者快速發(fā)現(xiàn) “某班級數(shù)學及格率低但優(yōu)秀率高” 的兩極分化現(xiàn)象,或 “某學科全年級缺考率異常” 的問題。

避坑指南:3D 圖表的常見問題與解決方案

數(shù)據(jù)遮擋問題

  • 現(xiàn)象:上層條形遮擋下層數(shù)據(jù),尤其是堆疊層數(shù)多或透明度低時。
  • 解決方案:
    • 增加透明度(alpha=0.6
    • 調整視角,讓上層條形 “傾斜” 露出下層(通過view_init設置仰角和方位角)
    • 減少堆疊層數(shù)(建議不超過 6 層,超過后信息會過載)

性能卡頓

  • 現(xiàn)象:數(shù)據(jù)量過大(如 20x20x10)時,繪圖速度變慢。
  • 解決方案:
    • 簡化數(shù)據(jù):對稀疏數(shù)據(jù)進行聚合(如求平均值)
    • 降低圖形復雜度:減小dx/dy值,或關閉不必要的網(wǎng)格和背景渲染

顏色混淆

  • 現(xiàn)象:相近顏色的堆疊層難以區(qū)分。
  • 解決方案:
    • 使用色盲友好調色板(如plt.cm.tab10
    • 在每層條形頂部添加數(shù)據(jù)標簽(見前文代碼)
    • 在圖例中說明各層顏色對應的含義(需額外編寫圖例代碼)

進階玩法:讓 3D 圖表更動態(tài)

1. 交互式旋轉與縮放

Matplotlib 默認支持鼠標交互:

左鍵拖動:旋轉視角

右鍵拖動:平移畫布

滾輪:縮放視圖

配合plt.ion()(交互模式),可以在 Jupyter Notebook 中實時調整視角。

2. 動畫效果(生成 GIF)

from matplotlib.animation import FuncAnimation

def update(frame):
    ax.view_init(elev=30, azim=frame)  # 動態(tài)改變方位角
    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軸總和的折線圖

結語:讓數(shù)據(jù)在三維空間中舞動

3D 堆疊條形圖就像一個數(shù)據(jù)舞臺,每個條形都是舞臺上的舞者,用高度和顏色演繹數(shù)據(jù)的故事。通過今天的教程,你已經(jīng)掌握了從數(shù)據(jù)準備到細節(jié)優(yōu)化的全流程,現(xiàn)在只差替換成你自己的數(shù)據(jù)啦!

替換數(shù)據(jù)的關鍵步驟回顧:

  • 確保你的數(shù)據(jù)是三維數(shù)組,形狀為[num_x, num_y, num_stacks]
  • 替換代碼中data = np.random.randint(...)這一行,直接賦值為你的數(shù)據(jù)
  • 根據(jù)數(shù)據(jù)含義修改坐標軸標簽(set_xlabel/set_ylabel/set_zlabel)和標題

快去試試吧!無論是分析商業(yè)數(shù)據(jù)還是科研成果,這種立體可視化方式都會讓你的報告瞬間提升一個檔次~

到此這篇關于使用Python繪制3D堆疊條形圖全解析的文章就介紹到這了,更多相關Python繪制3D堆疊條形圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • python讀寫csv文件并增加行列的實例代碼

    python讀寫csv文件并增加行列的實例代碼

    這篇文章主要介紹了python讀寫csv文件并增加行列的實現(xiàn)方法,文中給大家介紹了python寫入csv文件的幾種方法總結,給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • pandas中NaN缺失值的處理方法

    pandas中NaN缺失值的處理方法

    當我們用python進行數(shù)據(jù)處理時會遇到很多缺失值,對缺失值我們需要進行刪除或者填補,本文主要介紹了pandas中NaN缺失值的處理方法,感興趣的可以了解一下
    2021-05-05
  • 關于pandas-profiling的降級之旅

    關于pandas-profiling的降級之旅

    這篇文章主要介紹了關于pandas-profiling的降級之旅,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Python unittest模塊用法實例分析

    Python unittest模塊用法實例分析

    這篇文章主要介紹了Python unittest模塊用法,結合實例形式分析了unittest模塊功能及相關函數(shù)使用技巧,需要的朋友可以參考下
    2018-05-05
  • Python中函數(shù)的返回值示例淺析

    Python中函數(shù)的返回值示例淺析

    這篇文章主要給大家介紹了關于Python中函數(shù)返回值的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Python具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-08-08
  • Python中編寫ORM框架的入門指引

    Python中編寫ORM框架的入門指引

    這篇文章主要介紹了Python中編寫ORM框架的入門指引,示例代碼基于Python2.x版本,需要的朋友可以參考下
    2015-04-04
  • 分享幾道你可能遇到的python面試題

    分享幾道你可能遇到的python面試題

    最近去筆試,在面試過程中遇到了幾個編程題,比較基礎。所以想著總結一下,所以下面這篇文章主要給大家分享了幾道你可能遇到的python面試題,文中給出了詳細的示例代碼供大家參考學習,需要的朋友們下面來一起看看吧。
    2017-07-07
  • Django 解決distinct無法去除重復數(shù)據(jù)的問題

    Django 解決distinct無法去除重復數(shù)據(jù)的問題

    這篇文章主要介紹了Django 解決distinct無法去除重復數(shù)據(jù)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • Django unittest 設置跳過某些case的方法

    Django unittest 設置跳過某些case的方法

    今天小編就為大家分享一篇Django unittest 設置跳過某些case的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • Python給文件夾加解密的實現(xiàn)

    Python給文件夾加解密的實現(xiàn)

    數(shù)據(jù)泄露已經(jīng)成為一個嚴重的問題,為了保護用戶和公司的隱私,給文件夾加密已經(jīng)成為一個必要的步驟,本文主要介紹了Python給文件夾加解密的實現(xiàn),感興趣的可以了解一下
    2023-11-11

最新評論