您好,登錄后才能下訂單哦!
這篇文章主要講解了“matplotlib如何共享坐標(biāo)軸”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“matplotlib如何共享坐標(biāo)軸”吧!
1. 概述
共享坐標(biāo)軸就是幾幅子圖之間共享x軸或y軸,這一部分主要了解如何在利用matplotlib制圖時(shí)共享坐標(biāo)軸。
pyplot.subplots(nrows = 1,ncols = 1,sharex = False,sharey = False,
squeeze = True,subplot_kw =無(wú),gridspec_kw =無(wú),** fig_kw )
參數(shù):
nrows:行數(shù)
ncols:列數(shù)
sharex:是否共享X軸坐標(biāo)
sharey:是否共享Y軸坐標(biāo)
返回值:Figure,Axes對(duì)象數(shù)組
'''
1. 程序目的:
基于sharex和sharey實(shí)現(xiàn)
(1) 共享x軸
(2) 共享y軸
(3) 同時(shí)共享x軸和y軸
(4) 調(diào)整子圖之間的距離
2. 版本
2.1 山東青島 2021年5月18日 Version 1
'''
# 1. 相關(guān)模塊導(dǎo)入
import numpy as np
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['SimHei'] # 正常顯示中文字體
plt.rcParams['axes.unicode_minus'] = False # 正常顯示負(fù)號(hào)
# 2. 創(chuàng)建制圖數(shù)據(jù)
x = np.linspace(-5,5,100)
y_1 = np.sin(x)
y_2 = np.cos(x)
y_3 = y_2*2
# 3. 繪圖
# 3.1 共享X軸
figure,(ax1,ax2,ax3) = plt.subplots(3,1,
figsize=(5,6),
dpi=600,
# 共享x軸
sharex=True)
ax1.plot(x,y_1,c='blue',linestyle=':')
ax2.plot(x,y_2,c='orange',linestyle=':')
ax3.plot(x,y_3,c='r',linestyle=':')
# 調(diào)整子圖形之間的縱向距離
figure.subplots_adjust(hspace=0.1)
ax1.set_title('以下三圖共享了X軸') # 其實(shí)更合理的添加圖名時(shí)figure.subtitle()
# 3.2 共享Y軸
# 創(chuàng)建新的繪圖figure和axes對(duì)象
figure,(ax1,ax2,ax3) = plt.subplots(1,3,
figsize=(6,2),
dpi=600,
# 共享y軸
sharey=True)
figure.suptitle('以下三圖共享了Y軸')
ax1.plot(x,y_1,c='blue',linestyle=':')
ax2.plot(x,y_2,c='orange',linestyle=':')
ax3.plot(x,y_3,c='r',linestyle=':')
# 調(diào)整子圖形之間的橫向距離
figure.subplots_adjust(wspace=0.1)
# 3.3 同時(shí)共享x軸和y軸
# 創(chuàng)建新的繪圖figure和axes對(duì)象
figure,(ax1,ax2,ax3) = plt.subplots(1,3,
figsize=(6,2),
dpi=600,
# 共享x軸
sharex=True,
# 共享y軸
sharey=True)
x4 = np.linspace(-10,10,100)
y_4 = np.cos(x4)*2
figure.suptitle('以下三圖同時(shí)共享了X軸和Y軸')
ax1.plot(x,y_1,c='blue',linestyle=':')
ax2.plot(x,y_2,c='orange',linestyle=':')
ax3.plot(x4,y_4,c='r',linestyle=':')
# 調(diào)整子圖形之間的橫向距離
figure.subplots_adjust(wspace=0.1)
plt.show()
import matplotlib.pyplot as plt
import numpy as np
plt.rcParams['font.sans-serif']=['SimHei']
plt.rcParams['axes.unicode_minus']=False
x=np.linspace(0,2*np.pi,500)
y=np.sin(x)*np.exp(-x)
fig,ax=plt.subplots(nrows=1,ncols=2,sharey=True)
ax1=ax[0]
ax1.plot(x,y)
ax1.set_title("折線圖")
ax2=ax[1]
ax2.scatter(x,y)
ax2.set_title("散點(diǎn)圖")
plt.suptitle("一張畫布兩個(gè)子圖,并共享y坐標(biāo)")
#刪除空隙wspace為兩圖的水平距離,hspace為兩圖的垂直距離
fig.subplots_adjust(wspace=0)
plt.show()
import matplotlib.pyplot as plt
import numpy as np
plt.rcParams['font.sans-serif']=['SimHei']
plt.rcParams['axes.unicode_minus']=False
x=np.linspace(0,2*np.pi,500)
y=np.sin(x)*np.exp(-x)
fig,ax=plt.subplots(nrows=1,ncols=1)
ax.plot(x,y)
ax.set_title("折線圖")
ax.scatter(x,y[::-1])
plt.suptitle("共享單一繪圖區(qū)域的坐標(biāo)軸")
plt.show()
感謝各位的閱讀,以上就是“matplotlib如何共享坐標(biāo)軸”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)matplotlib如何共享坐標(biāo)軸這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。