如何用Python绘制3D柱形图

作者:NewRookie 时间:2022-12-19 04:22:04 

本文主要讲解如何使用python绘制三维的柱形图,如下图

如何用Python绘制3D柱形图

源代码如下:


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

#构造需要显示的值
X=np.arange(0, 5, step=1)#X轴的坐标
Y=np.arange(0, 9, step=1)#Y轴的坐标
#设置每一个(X,Y)坐标所对应的Z轴的值,在这边Z(X,Y)=X+Y
Z=np.zeros(shape=(5, 9))
for i in range(5):
 for j in range(9):
   Z[i, j]=i+j

xx, yy=np.meshgrid(X, Y)#网格化坐标
X, Y=xx.ravel(), yy.ravel()#矩阵扁平化
bottom=np.zeros_like(X)#设置柱状图的底端位值
Z=Z.ravel()#扁平化矩阵

width=height=1#每一个柱子的长和宽

#绘图设置
fig=plt.figure()
ax=fig.gca(projection='3d')#三维坐标轴
ax.bar3d(X, Y, bottom, width, height, Z, shade=True)#
#坐标轴设置
ax.set_xlabel('X')
ax.set_ylabel('Y')
ax.set_zlabel('Z(value)')
plt.show()

代码解读:

1、构造需要显示的数据

如下图所示,X坐标取值为[0,1,2,3,4],Y坐标取值为[0,1,2,3,4,5,6,7,8],每一个(X,Y)组合的值Z=X+Y,所需要绘制的图就是在X,Y所对应的坐标位置上面根据Z的值来绘制柱形图。

如何用Python绘制3D柱形图

2、坐标设置

将坐标网格化, X=[0,1,2,3,4],Y=[0,1,2,3,4,5,6,7,8]网格化的结果,如下图所示。可以理解为,X参照Y进行了广播(broadcast), Y参照X进行了广播,分别添加了一个新的维度,并且进行复制。结合xx和yy就得到了所有的X,Y的坐标组合,经过扁平化之后这种对应关系保持不变。代码中的bottom是用来设置绘制每一个柱子的Z坐标的,在此全部都设置为0,而width和height设置每一个柱子的长和宽。

如何用Python绘制3D柱形图

3、bar3d

ax.bar3d(X, Y, bottom, width, height, Z, shade=True):
X,Y:柱子在XY平面的起始坐标
bottom:柱子在Z轴上的起始坐标
width、height:柱子的长宽
Z:数字沿Z轴的长度
shade:是否显示阴影(设置为True立体效果会更好)

shde=True

如何用Python绘制3D柱形图

shade=False

如何用Python绘制3D柱形图

如果需要绘制多个子图,并且里面每一个子图都是3D的,只需要将上述代码进行些许修改即可,案例如下:


fig=plt.figure()
 ax=fig.add_subplot(1, 3, 1, projection='3d')
 ax.bar3d(x, y, z, width, height, top, shade=True)

ax=fig.add_subplot(1, 3, 2, projection='3d')
 ax.bar3d(x, y, z, width, height, top2, shade=True)

ax=fig.add_subplot(1, 3, 3, projection='3d')
 ax.bar3d(x, y, z, width, height, top3, shade=True)

plt.show()

来源:https://www.cnblogs.com/AlgrithmsRookie/p/11677614.html

标签:python,绘制,3d,柱形图
0
投稿

猜你喜欢

  • CKeditor富文本编辑器使用技巧之添加自定义插件的方法

    2024-04-18 09:52:24
  • python的多线程原来可以这样解

    2021-02-22 16:12:18
  • Vue简易版无限加载组件实现原理与示例代码

    2024-04-28 10:54:53
  • javascript 数组(list)添加/删除的实现

    2024-04-17 10:37:25
  • MySQL删除数据Delete与Truncate语句使用比较

    2024-01-15 05:12:42
  • asp如何制作一个WAP手机的WML网页?

    2010-06-29 21:21:00
  • 商业价值与用户价值的平衡

    2008-12-10 18:42:00
  • Python淘宝或京东等秒杀抢购脚本实现(秒杀脚本)

    2023-01-23 20:25:14
  • python计算机视觉opencv矩形轮廓顶点位置确定

    2022-06-07 16:30:44
  • Mysql中文乱码问题的最佳解决方法

    2024-01-21 11:11:50
  • 在Python上基于Markov链生成伪随机文本的教程

    2023-07-02 09:24:03
  • Python使用xlrd和xlwt实现自动化操作Excel

    2021-08-24 10:54:19
  • sql语句之数据操作介绍

    2024-01-22 18:09:39
  • 解决goland 导入项目后import里的包报红问题

    2024-04-25 15:09:39
  • php写入mysql中文乱码的实例解决方法

    2023-10-10 01:36:49
  • python得到单词模式的示例

    2021-04-22 08:25:48
  • Django自定义用户认证示例详解

    2022-02-03 01:31:18
  • OpenCV图像修复cv2.inpaint()的使用

    2022-07-03 05:47:57
  • Python将图片转换为字符画的方法

    2022-06-15 07:52:27
  • 分页存储过程(用存储过程实现数据库的分页代码)

    2024-01-20 05:22:57
  • asp之家 网络编程 m.aspxhome.com