你在那里犯了一些小错误。首先plt.subplot()
命令覆盖你的host_subplot()
命令(参见matplotlib.pyplot.subplot() 文档中的注释 https://matplotlib.org/api/_as_gen/matplotlib.pyplot.subplot.html:“创建子图将删除任何与其重叠且超出共享边界的现有子图”)。此外,您必须分别跟踪两个图的实例。我像这样解决了我创建的问题host1
, par11
, and par12
为了第一Axes
and host2
, par21
, and par22
第二个Axes
。整个代码现在看起来像这样:
import matplotlib.pyplot as plt
from mpl_toolkits.axes_grid1 import host_subplot
import mpl_toolkits.axisartist as AA
fig = plt.figure()
host1 = host_subplot(211, axes_class=AA.Axes)
plt.subplots_adjust(right=0.75)
par11 = host1.twinx()
par12 = host1.twinx()
offset = 60
new_fixed_axis = par12.get_grid_helper().new_fixed_axis
par12.axis["right"] = new_fixed_axis(loc="right",
axes=par12,
offset=(offset, 0))
par11.axis["right"].toggle(all=True)
par12.axis["right"].toggle(all=True)
host1.set_xlim(0, 2)
host1.set_ylim(0, 2)
host1.set_xlabel("Distance")
host1.set_ylabel("Density")
par11.set_ylabel("Temperature")
par12.set_ylabel("Velocity")
p1, = host1.plot([0, 1, 2], [0, 1, 2], label="Density")
p2, = par11.plot([0, 1, 2], [0, 3, 2], label="Temperature")
p3, = par12.plot([0, 1, 2], [50, 30, 15], label="Velocity")
par11.set_ylim(0, 4)
par12.set_ylim(1, 65)
host1.legend()
host1.axis["left"].label.set_color(p1.get_color())
par11.axis["right"].label.set_color(p2.get_color())
par12.axis["right"].label.set_color(p3.get_color())
#####2#####
host2 = host_subplot(212, axes_class=AA.Axes)
plt.subplots_adjust(right=0.75)
par21 = host2.twinx()
par22 = host2.twinx()
offset = 60
new_fixed_axis = par22.get_grid_helper().new_fixed_axis
par22.axis["right"] = new_fixed_axis(loc="right",
axes=par22,
offset=(offset, 0))
par21.axis["right"].toggle(all=True)
par22.axis["right"].toggle(all=True)
host2.set_xlim(0, 2)
host2.set_ylim(0, 2)
host2.set_xlabel("Distance")
host2.set_ylabel("Density")
par21.set_ylabel("Temperature")
par22.set_ylabel("Velocity")
p1, = host2.plot([0, 1, 2], [0, 1, 2], label="Density")
p2, = par21.plot([0, 1, 2], [0, 3, 2], label="Temperature")
p3, = par22.plot([0, 1, 2], [50, 30, 15], label="Velocity")
par21.set_ylim(0, 4)
par22.set_ylim(1, 65)
host2.legend()
host2.axis["left"].label.set_color(p1.get_color())
par21.axis["right"].label.set_color(p2.get_color())
par22.axis["right"].label.set_color(p3.get_color())
fig.tight_layout()
plt.draw()
plt.show()
这是结果:
希望这可以帮助。