如何用Python绘制3D柱形图


Posted in Python onSeptember 16, 2020

本文主要讲解如何使用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()

以上就是如何用Python绘制3D柱形图的详细内容,更多关于python绘制柱形图的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python用10行代码实现对黄色图片的检测功能
Aug 10 Python
详解Python命令行解析工具Argparse
Apr 20 Python
python+pyqt实现12306图片验证效果
Oct 25 Python
使用python和Django完成博客数据库的迁移方法
Jan 05 Python
ubuntu安装mysql pycharm sublime
Feb 20 Python
Python对接 xray 和微信实现自动告警
Sep 17 Python
解决更改AUTH_USER_MODEL后出现的问题
May 14 Python
Python 私有属性和私有方法应用场景分析
Jun 19 Python
PyCharm设置注释字体颜色以及是否倾斜的操作
Sep 16 Python
Python通过yagmail实现发送邮件代码解析
Oct 27 Python
详解Scrapy Redis入门实战
Nov 18 Python
Pandas-DataFrame知识点汇总
Mar 16 Python
Python Merge函数原理及用法解析
Sep 16 #Python
简单了解Python字典copy与赋值的区别
Sep 16 #Python
python 服务器运行代码报错ModuleNotFoundError的解决办法
Sep 16 #Python
pycharm2020.2 配置使用的方法详解
Sep 16 #Python
python Matplotlib模块的使用
Sep 16 #Python
Python类成员继承重写的实现
Sep 16 #Python
PyCharm设置注释字体颜色以及是否倾斜的操作
Sep 16 #Python
You might like
snoopy 强大的PHP采集类使用实例代码
2010/12/09 PHP
PHP的构造方法,析构方法和this关键字详细介绍
2013/10/22 PHP
PHP使用mysqldump命令导出数据库
2015/04/14 PHP
php中的常用魔术方法汇总
2016/02/14 PHP
thinkPHP中配置的读取与C方法详解
2016/12/05 PHP
Jquery 动态添加按钮实现代码
2010/05/06 Javascript
使用javascript实现雪花飘落的效果
2015/01/13 Javascript
jQuery插件ajaxFileUpload实现异步上传文件效果
2015/04/14 Javascript
基于jQuery实现的菜单切换效果
2015/10/16 Javascript
JavaScript中的this机制
2016/01/30 Javascript
分享12个实用的jQuery代码片段
2016/03/09 Javascript
理解javascript模块化
2016/03/28 Javascript
vue2 中如何实现动态表单增删改查实例
2017/06/09 Javascript
JS如何实现在页面上快速定位(锚点跳转问题)
2017/08/14 Javascript
axios拦截设置和错误处理方法
2018/03/05 Javascript
浅谈KOA2 Restful方式路由初探
2019/03/14 Javascript
javascript数组的定义及操作实例
2019/11/10 Javascript
详解JavaScript之ES5的继承
2020/07/08 Javascript
[07:12]2014DOTA2西雅图国际邀请赛 黑马Liquid专题采访
2014/07/12 DOTA
Python中分支语句与循环语句实例详解
2018/09/13 Python
pyttsx3实现中文文字转语音的方法
2018/12/24 Python
Python2和Python3之间的str处理方式导致乱码的讲解
2019/01/03 Python
PyQt5中QTableWidget如何弹出菜单的示例代码
2020/02/23 Python
Django 再谈一谈json序列化
2020/03/16 Python
Python基于wordcloud及jieba实现中国地图词云图
2020/06/09 Python
解决pytorch多GPU训练保存的模型,在单GPU环境下加载出错问题
2020/06/23 Python
CSS3系列之3D制作方法案例
2017/08/14 HTML / CSS
HTML5中meta属性的使用方法
2016/02/29 HTML / CSS
浅谈Html5中视频 音频标签 进度条的问题
2016/07/26 HTML / CSS
英国创新设计文具、卡片和礼品包装网站:Paperchase
2018/07/14 全球购物
英国空调、除湿机和通风设备排名第一:Air Con Centre
2019/02/25 全球购物
母亲80寿诞答谢词
2014/01/16 职场文书
会走路的树教学反思
2014/02/20 职场文书
2014年出纳工作总结与计划
2014/12/09 职场文书
交通处罚决定书
2015/06/24 职场文书
2015年幼儿园国庆节活动总结
2015/07/30 职场文书