Python+Matplotlib繪制3D圖像的示例詳解
1. 繪制3D柱狀圖
繪制3D柱狀圖使用的是axes3d.bar()方法。
可能跟我們中學(xué)學(xué)的有一點(diǎn)不同的是,其語(yǔ)法如下:
bar(left, height, zs=0, zdir=‘z’, *args, **kwargs)
其中l(wèi)eft表示指向側(cè)邊的軸,zs表示指向我們的方向的軸,height即表示高度的軸。這三者都需要是一維的序列對(duì)象。
在調(diào)用相關(guān)方法的時(shí)候,比如設(shè)置軸標(biāo)簽,還有一點(diǎn)需要區(qū)分的是,left對(duì)應(yīng)的是y軸,zs對(duì)應(yīng)的是x軸。(意思就是說(shuō),比如使用plt.xticks()方法,操作的是zs;而使用plt.yticks()方法則操作的是left軸。height對(duì)應(yīng)著z軸。)
一段完整的代碼示例如下:
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d.axes3d import Axes3D
import numpy as np
plt.rcParams['axes.unicode_minus'] = False
plt.rcParams['axes.facecolor'] = '#cc00ff'
plt.rcParams['font.sans-serif'] = ['STKAITI']
# 創(chuàng)建畫(huà)布
fig = plt.figure()
# 創(chuàng)建3D坐標(biāo)系
axes3d = Axes3D(fig)
zs = range(5)
left = np.arange(0, 10)
height = np.array([])
for i in range(len(zs)):
z = zs[i]
np.random.seed(i)
height = np.random.randint(0, 30, size=10)
axes3d.bar(left, height, zs=z, zdir='x',
color=['red', 'green', 'purple', 'yellow', 'blue', 'black', 'gray', 'orange', 'pink', 'cyan'])
plt.xticks(zs, ['1月份', '2月份', '3月份', '4月份', '5月份'])
plt.yticks(left, ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'G'])
plt.xlabel('月份')
plt.ylabel('型號(hào)')
plt.show()
圖像效果如下:

2. 繪制3D曲面圖
示例1
繪制曲面圖使用的是plot_surface()方法,這個(gè)方法的參數(shù)相對(duì)而言更簡(jiǎn)單。且X、Y、Z三者的順序相對(duì)較為容易分辨。
通過(guò)讀示例代碼,即可快速掌握其用法:
import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D
plt.rcParams['font.sans-serif'] = ['STKAITI']
plt.rcParams['axes.unicode_minus'] = False
plt.rcParams['axes.facecolor'] = '#cc00ff'
fig = plt.figure(figsize=(10, 8), facecolor='#cc00ff')
ax = Axes3D(fig)
delta = 0.125
# 生成代表X軸數(shù)據(jù)的列表
x = np.arange(-4.0, 4.0, delta)
# 生成代表Y軸數(shù)據(jù)的列表
y = np.arange(-3.0, 4.0, delta)
# 對(duì)x、y數(shù)據(jù)執(zhí)行網(wǎng)格化
X, Y = np.meshgrid(x, y)
Z1 = np.exp(-X**2 - Y**2)
Z2 = np.exp(-(X - 1)**2 - (Y - 1)**2)
# 計(jì)算Z軸數(shù)據(jù)(高度數(shù)據(jù))
Z = (Z1 - Z2) * 2
# 繪制3D圖形
ax.plot_surface(X, Y, Z,
rstride=1, # rstride(row)指定行的跨度
cstride=1, # cstride(column)指定列的跨度
cmap=plt.get_cmap('rainbow')) # 設(shè)置顏色映射
plt.xlabel('X軸', fontsize=15)
plt.ylabel('Y軸', fontsize=15)
ax.set_zlabel('Z軸', fontsize=15)
ax.set_title('《曲面圖》', y=1.02, fontsize=25, color='gold')
# 設(shè)置Z軸范圍
ax.set_zlim(-2, 2)
plt.show()

示例2
更換一組數(shù)據(jù),呈現(xiàn)的則是另一種藝術(shù)效果:
import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D
plt.rcParams['font.sans-serif'] = ['STKAITI']
plt.rcParams['axes.unicode_minus'] = False
plt.rcParams['axes.facecolor'] = '#cc00ff'
fig = plt.figure(figsize=(12, 10), facecolor='#cc00ff')
ax = Axes3D(fig)
delta = 0.125
# 生成代表X軸數(shù)據(jù)的列表
x = np.linspace(-2, 2, 10)
# 生成代表Y軸數(shù)據(jù)的列表
y = np.linspace(-2, 2, 10)
# 對(duì)x、y數(shù)據(jù)執(zhí)行網(wǎng)格化
X, Y = np.meshgrid(x, y)
# 計(jì)算Z軸數(shù)據(jù)(高度數(shù)據(jù))
Z = X**2 - Y**2
# 繪制3D圖形
ax.plot_surface(X, Y, Z,
rstride=1, # rstride(row)指定行的跨度
cstride=1, # cstride(column)指定列的跨度
cmap=plt.get_cmap('rainbow')) # 設(shè)置顏色映射
plt.xlabel('X軸', fontsize=15)
plt.ylabel('Y軸', fontsize=15)
ax.set_zlabel('Z軸', fontsize=15)
ax.set_title('《曲面圖》', y=1.02, fontsize=25, color='gold')
plt.show()

3.繪制3D散點(diǎn)圖
在3D曲面圖示例1的基礎(chǔ)上稍作修改。
繪制散點(diǎn)圖使用scatter()方法,將散點(diǎn)顏色設(shè)置為綠色,紅色邊沿。
代碼示例如下:
import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D
plt.rcParams['font.sans-serif'] = ['STKAITI']
plt.rcParams['axes.unicode_minus'] = False
plt.rcParams['axes.facecolor'] = '#cc00ff'
fig = plt.figure(figsize=(10, 8), facecolor='#cc00ff')
ax = Axes3D(fig)
delta = 0.125
# 生成代表X軸數(shù)據(jù)的列表
x = np.arange(-4.0, 4.0, delta)
# 生成代表Y軸數(shù)據(jù)的列表
y = np.arange(-3.0, 4.0, delta)
# 對(duì)x、y數(shù)據(jù)執(zhí)行網(wǎng)格化
X, Y = np.meshgrid(x, y)
Z1 = np.exp(-X**2 - Y**2)
Z2 = np.exp(-(X - 1)**2 - (Y - 1)**2)
# 計(jì)算Z軸數(shù)據(jù)(高度數(shù)據(jù))
Z = (Z1 - Z2) * 2
# 繪制3D圖形
ax.scatter(X, Y, Z,
c='green',
edgecolors='red')
plt.xlabel('X軸', fontsize=15)
plt.ylabel('Y軸', fontsize=15)
ax.set_zlabel('Z軸', fontsize=15)
ax.set_title('《散點(diǎn)圖》', y=1.02, fontsize=25, color='gold')
# 設(shè)置Z軸范圍
ax.set_zlim(-2, 2)
plt.show()
繪圖效果如下:

4. 繪制3D曲線(xiàn)圖
繪制曲線(xiàn)圖,使用的則是我們最最最熟悉的plot()方法。
其他部分基本不變,數(shù)據(jù)部分生成三組適合我們繪圖的數(shù)據(jù),線(xiàn)條為金色,寬度設(shè)定為3.
代碼如下:
import matplotlib.pyplot as plt
import numpy as np
from mpl_toolkits.mplot3d import Axes3D
plt.rcParams['font.sans-serif'] = ['STKAITI']
plt.rcParams['axes.unicode_minus'] = False
plt.rcParams['axes.facecolor'] = '#cc00ff'
fig = plt.figure(figsize=(10, 8), facecolor='#cc00ff')
ax = Axes3D(fig)
theta = np.linspace(0, 3.14*10, 1000)
r = np.linspace(0, 1, 1000)
x = r * np.cos(theta)
y = r * np.sin(theta)
z = np.linspace(0, 4, 1000)
ax.plot(x, y, z, color='gold', lw=3)
plt.xlabel('X軸', fontsize=15)
plt.ylabel('Y軸', fontsize=15)
ax.set_zlabel('Z軸', fontsize=15)
ax.set_title('《曲線(xiàn)圖》', y=1.02, fontsize=25, color='gold')
plt.show()
圖像效果如下:

以上就是Python+Matplotlib繪制3D圖像的示例詳解的詳細(xì)內(nèi)容,更多關(guān)于Python Matplotlib 3D圖像的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python機(jī)器學(xué)習(xí)庫(kù)scikit-learn使用詳解
scikit-learn是Python中最流行的機(jī)器學(xué)習(xí)庫(kù)之一,它提供了各種各樣的機(jī)器學(xué)習(xí)算法和工具,包括分類(lèi)、回歸、聚類(lèi)、降維等2023-03-03
在FastAPI中改變響應(yīng)狀態(tài)碼的兩種方法
FastAPI,顧名思義,是一個(gè)快速、現(xiàn)代、高性能的web框架,用于用Python構(gòu)建后端api,響應(yīng)狀態(tài)碼是一個(gè)三位數(shù),表示請(qǐng)求的結(jié)果,在這篇簡(jiǎn)明的基于示例的博文中,我將向你展示在FastAPI中更改響應(yīng)狀態(tài)代碼的兩種不同方法,需要的朋友可以參考下2025-02-02
詳解centos7+django+python3+mysql+阿里云部署項(xiàng)目全流程
這篇文章主要介紹了詳解centos7+django+python3+mysql+阿里云部署項(xiàng)目全流程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
pycharm不在cmd中運(yùn)行卻在python控制臺(tái)運(yùn)行問(wèn)題解決
這篇文章主要介紹了pycharm不在cmd中運(yùn)行卻在python控制臺(tái)運(yùn)行問(wèn)題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
python 調(diào)用API接口 獲取和解析 Json數(shù)據(jù)
這篇文章主要介紹了python 如何調(diào)用API接口 獲取和解析 Json數(shù)據(jù),幫助大家更好的理解和使用python,感興趣的朋友可以了解下2020-09-09
python中使用多線(xiàn)程改進(jìn)flask案例
這篇文章主要介紹了使用多線(xiàn)程改進(jìn)flask案例,線(xiàn)程是指進(jìn)程內(nèi)的一個(gè)執(zhí)行單元,也是進(jìn)程內(nèi)的可調(diào)度實(shí)體.線(xiàn)程的劃分尺度小于進(jìn)程,使得多線(xiàn)程程序的并發(fā)性高,更多具體內(nèi)容,需要的小伙伴可以參考下面文章相關(guān)資料,希望對(duì)你有所幫助2022-03-03
超簡(jiǎn)單的scrapy實(shí)現(xiàn)ip動(dòng)態(tài)代理與更換ip的方法實(shí)現(xiàn)
這篇文章主要介紹了超簡(jiǎn)單的scrapy實(shí)現(xiàn)ip動(dòng)態(tài)代理與更換ip的方法實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
Python實(shí)現(xiàn)將MP4視頻轉(zhuǎn)化為GIF圖像
與靜態(tài)圖像相比,動(dòng)態(tài)的?GIF?圖片更能吸引各位讀者的注意力,還可以提供更生動(dòng)、有趣和引人入勝的內(nèi)容,本文為大家介紹了Python將MP4視頻轉(zhuǎn)化為GIF圖像的方法,需要的可以參考下2023-06-06

