本文小編為大家詳細(xì)介紹“Python數(shù)據(jù)科學(xué)Matplotlib圖庫(kù)怎么使用”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Python數(shù)據(jù)科學(xué)Matplotlib圖庫(kù)怎么使用”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來(lái)學(xué)習(xí)新知識(shí)吧。
創(chuàng)新互聯(lián)公司聯(lián)系電話(huà):18980820575,為您提供成都網(wǎng)站建設(shè)網(wǎng)頁(yè)設(shè)計(jì)及定制高端網(wǎng)站建設(shè)服務(wù),創(chuàng)新互聯(lián)公司網(wǎng)頁(yè)制作領(lǐng)域10余年,包括成都地磅秤等多個(gè)行業(yè)擁有豐富的營(yíng)銷(xiāo)推廣經(jīng)驗(yàn),選擇創(chuàng)新互聯(lián)公司,為企業(yè)保駕護(hù)航。
Matplotlib 是 Python 的二維繪圖庫(kù),用于生成符合出版質(zhì)量或跨平臺(tái)交互環(huán)境的各類(lèi)圖形。
Matplotlib 繪圖的基本步驟:
1 準(zhǔn)備數(shù)據(jù)
2 創(chuàng)建圖形
3 繪圖
4 自定義設(shè)置
5 保存圖形
6 顯示圖形
import matplotlib.pyplot as plt x = [1,2,3,4] # step1 y = [10,20,25,30] fig = plt.figure() # step2 ax = fig.add_subplot(111) # step3 ax.plot(x, y, color='lightblue', linewidth=3) # step3\4 ax.scatter([2,4,6], [5,15,25], color='darkgreen', marker='^') ax.set_xlim(1, 6.5) plt.savefig('foo.png') # step5 plt.show() # step6
一維數(shù)據(jù)
import numpy as np x = np.linspace(0, 10, 100) y = np.cos(x) z = np.sin(x)
二維數(shù)據(jù)或圖片
data = 2 * np.random.random((10, 10)) data2 = 3 * np.random.random((10, 10)) Y, X = np.mgrid[-3:3:100j, -3:3:100j] U = -1 - X**2 + Y V = 1 + X - Y**2 from matplotlib.cbook import get_sample_data img = np.load('E:/anaconda3/envs/torch/Lib/site-packages/matplotlib/mpl-data/aapl.npz')
繪制圖形
import matplotlib.pyplot as plt
畫(huà)布
fig = plt.figure() fig2 = plt.figure(figsize=plt.figaspect(2.0))
坐標(biāo)軸
圖形是以坐標(biāo)軸為核心繪制的,大多數(shù)情況下,子圖就可以滿(mǎn)足需求。子圖是柵格系統(tǒng)的坐標(biāo)軸。
fig.add_axes() ax1 = fig.add_subplot(221) # row-col-num ax3 = fig.add_subplot(212) fig3, axes = plt.subplots(nrows=2,ncols=2) fig4, axes2 = plt.subplots(ncols=3)
一維數(shù)據(jù)
fig, ax = plt.subplots() lines = ax.plot(x,y) # 用線(xiàn)或標(biāo)記連接點(diǎn) ax.scatter(x,y) # 縮放或著色未連接的點(diǎn) axes[0,0].bar([1,2,3],[3,4,5]) # 繪制等寬縱向矩形 axes[1,0].barh([0.5,1,2.5],[0,1,2]) # 繪制等高橫向矩形 axes[1,1].axhline(0.45) # 繪制與軸平行的橫線(xiàn) axes[0,1].axvline(0.65) # 繪制與軸垂直的豎線(xiàn) ax.fill(x,y,color='blue') # 繪制填充多邊形 ax.fill_between(x,y,color='yellow') # 填充y值和0之間
二維數(shù)據(jù)或圖片
import matplotlib.image as imgplt img = imgplt.imread('C:/Users/Administrator/Desktop/timg.jpg') fig, ax = plt.subplots() im = ax.imshow(img, cmap='gist_earth', interpolation='nearest', vmin=-200, vmax=200)# 色彩表或RGB數(shù)組 axes2[0].pcolor(data2) # 二維數(shù)組偽彩色圖 axes2[0].pcolormesh(data) # 二維數(shù)組等高線(xiàn)偽彩色圖 CS = plt.contour(Y,X,U) # 等高線(xiàn)圖 axes2[2].contourf(data) axes2[2]= ax.clabel(CS) # 等高線(xiàn)圖標(biāo)簽
向量場(chǎng)
axes[0,1].arrow(0,0,0.5,0.5) # 為坐標(biāo)軸添加箭頭 axes[1,1].quiver(y,z) # 二維箭頭 axes[0,1].streamplot(X,Y,U,V) # 二維箭頭
數(shù)據(jù)分布
ax1.hist(y) # 直方圖 ax3.boxplot(y) # 箱形圖 ax3.violinplot(z) # 小提琴圖
自定義圖形 顏色、色條與色彩表
plt.plot(x, x, x, x**2, x, x**3) ax.plot(x, y, alpha = 0.4) ax.plot(x, y, c='k') fig.colorbar(im, orientation='horizontal') im = ax.imshow(img, cmap='seismic')
標(biāo)記
fig, ax = plt.subplots() ax.scatter(x,y,marker=".") ax.plot(x,y,marker="o")
線(xiàn)型
plt.plot(x,y,linewidth=4.0) plt.plot(x,y,ls='solid') plt.plot(x,y,ls='--') plt.plot(x,y,'--',x**2,y**2,'-.') plt.setp(lines,color='r',linewidth=4.0)
文本與標(biāo)注
ax.text(1, -2.1, 'Example Graph', style='italic') ax.annotate("Sine", xy=(8, 0), xycoords='data', xytext=(10.5, 0), textcoords='data', arrowprops=dict(arrow, connection),)
數(shù)學(xué)符號(hào)
plt.title(r'$sigma_i=15$', fontsize=20)
尺寸限制與自動(dòng)調(diào)整
ax.margins(x=0.0,y=0.1) # 添加內(nèi)邊距 ax.axis('equal') # 將圖形縱橫比設(shè)置為1 ax.set(xlim=[0,10.5],ylim=[-1.5,1.5]) # 設(shè)置x軸與y軸的限 ax.set_xlim(0,10.5)
圖例
ax.set(title='An Example Axes', ylabel='Y-Axis', xlabel='X-Axis') # 設(shè)置標(biāo)題與x、y軸的標(biāo)簽 ax.legend(loc='best') # 自動(dòng)選擇最佳的圖例位置
標(biāo)記
ax.xaxis.set(ticks=range(1,5), ticklabels=[3,100,-12,"foo"]) # 手動(dòng)設(shè)置X軸刻度 ax.tick_params(axis='y', direction='inout', length=10) # 設(shè)置Y軸長(zhǎng)度與方向
子圖間距
fig3.subplots_adjust(wspace=0.5, hspace=0.3, left=0.125, right=0.9, top=0.9, bottom=0.1) fig.tight_layout() # 設(shè)置畫(huà)布的子圖布局
坐標(biāo)軸邊線(xiàn)
ax1.spines['top'].set_visible(False) # 隱藏頂部坐標(biāo)軸線(xiàn) ax1.spines['bottom'].set_position(('outward',10)) # 設(shè)置底部邊線(xiàn)的位置為outward
保存
#保存畫(huà)布 plt.savefig('foo.png') # 保存透明畫(huà)布 plt.savefig('foo.png', transparent=True)
顯示圖形
plt.show()
關(guān)閉與清除
plt.cla() # 清除坐標(biāo)軸 plt.clf() # 清除畫(huà)布 plt.close() # 關(guān)閉窗口
讀到這里,這篇“Python數(shù)據(jù)科學(xué)Matplotlib圖庫(kù)怎么使用”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過(guò)才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
當(dāng)前文章:Python數(shù)據(jù)科學(xué)Matplotlib圖庫(kù)怎么使用
文章鏈接:http://aaarwkj.com/article34/igsese.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、網(wǎng)站導(dǎo)航、App開(kāi)發(fā)、企業(yè)網(wǎng)站制作、全網(wǎng)營(yíng)銷(xiāo)推廣、服務(wù)器托管
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)