Вы можете учесть необходимое с помощью цветовой шкалы уже при создании вспомогательных участков.Вместо использования делителя создайте четыре вспомогательных участка различной ширины, используя gridspec_kw
.Затем вы можете удалить ненужные cax
для второго подпункта:
import matplotlib.pyplot as plt
import numpy as np
x = np.linspace(0, 10, num=100)
y = x ** 2 + 10 * np.random.randn(100)
##creating four subplots with unequally divided widths:
f, axes = plt.subplots(
2,2, sharex='col', figsize=(8,12),
gridspec_kw = {'width_ratios' : (10,1)},
)
ax1,ax2 = axes[:,0]
##remove unneeded Axes instance:
axes[1,1].remove()
im1 = ax1.scatter(x, y, c=y, cmap='magma')
plt.colorbar(im1, cax=axes[0,1])
im2 = ax2.plot(x, y,'.')
f.savefig('sharex_colorbar.png')
Результат выглядит следующим образом:

В качестве альтернативы удалению ненужных экземпляров вспомогательных участков вы также можете сначала явно сгенерировать сеточную спецификацию и создать только необходимые вспомогательные участки.Это может быть более подходящим, если у вас есть много участков:
from matplotlib.gridspec import GridSpec
gs = GridSpec(nrows=2, ncols=2, width_ratios = (10,1))
f = plt.figure(figsize=(8,12))
ax1 = f.add_subplot(gs[0,0])
ax2 = f.add_subplot(gs[1,0],sharex=ax1)
cax = f.add_subplot(gs[0,1])
im1 = ax1.scatter(x, y, c=y, cmap='magma')
plt.colorbar(im1, cax=cax)