Python 官方文档:入门教程 => 点击学习
引入模块 import numpy as npimport matplotlib.pyplot as pltimport matplotlib 创建3D图代码 # 创建窗口fig=plt.figure
import numpy as npimport matplotlib.pyplot as pltimport matplotlib
# 创建窗口fig=plt.figure()# 在该窗口中创建3d绘图对象ax=Axes3D(fig)# 创建点的x和y坐标数组x=np.arange(-3,3,0.2)y=np.arange(-3,3,0.2)# 网格化处理x,y=np.meshgrid(x,y)# 计算某个点到原点的距离为半径r=np.sqrt(x**2+y**2)# 以半径为基准,求它的正弦值为点的z轴坐标z=np.sin(r)# 绘制图像ax.plot_surface(x,y,z,rstride=3,cstride=1,cmap="hot")# 底部的投影ax.contour(x,y,z, zdir = 'z', offset = -1, cmap = plt.get_cmap('rainbow'))# 设置z轴的维度,x,y类似ax.set_zlim(-2, 2)plt.show()
这是网上大多都这样写的,执行发现一片空白不出图。
百度之后,有说降到3.8就可以了,结论是3.9以上已经不支持此绘图了。
继续查找,随后有说加fig.add_axes(ax)
试了试,出图了
ax=Axes3D(fig)fig.add_axes(ax)
# 3D图matplotlib.rcParams['axes.unicode_minus']=False# 创建窗口fig=plt.figure()# 在该窗口中创建3d绘图对象ax=Axes3D(fig)fig.add_axes(ax)# 创建点的x和y坐标数组x=np.arange(-3,3,0.2)y=np.arange(-3,3,0.2)# 网格化处理x,y=np.meshgrid(x,y)# 计算某个点到原点的距离为半径r=np.sqrt(x**2+y**2)# 以半径为基准,求它的正弦值为点的z轴坐标z=np.sin(r)# 绘制图像ax.plot_surface(x,y,z,rstride=3,cstride=1,cmap="hot")# 底部的投影ax.contour(x,y,z, zdir = 'z', offset = -1, cmap = plt.get_cmap('rainbow'))# 设置z轴的维度,x,y类似ax.set_zlim(-2, 2)plt.show()
--结束END--
本文标题: python3.10 Axes3D绘制3d图不出图解决办法
本文链接: https://www.lsjlt.com/news/406093.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0