Matplotlib вторичных осей, которая охватывает половину первой - PullRequest
0 голосов
/ 15 ноября 2011

Мне нужен график с двумя осями y, но второй должен быть половиной первого.

Я думал о двух разных участках, но я думаю, что есть более простой способ.

Большое спасибо.

1 Ответ

0 голосов
/ 16 ноября 2011

Вы должны проверить галерею matplotlib.
Может быть, вы ищете что-то вроде это или это .

Тогда, если вы хотите, чтобы ax2 (правая ось) охватила половину ax1 (левая ось), получите y-пределы ax1:

(min_y, max_y) = ax1.get_ylim()

и установите пределы ax2 соответственно. Например:

ax2.set_ylim((min_y, max_y / 2.))

Редактировать:

После ваших комментариев я разработал решение, которое, вероятно, лучше соответствует вашим потребностям. Вот код, модифицированный из галереи mpl:

import numpy as np
import matplotlib.pyplot as plt

fig = plt.figure()
ax1 = fig.add_subplot(111)
t = np.arange(0.01, 10.0, 0.01)
s1 = np.exp(t)
ax1.plot(t, s1, 'b-')
ax1.set_xlabel('time (s)')
ax1.set_ylabel('exp', color='b')

for tl in ax1.get_yticklabels():
    tl.set_color('b')

ax2 = ax1.twinx()
s2 = np.sin(2*np.pi*t)
ax2.plot(t, s2, 'r.')
ax2.set_ylabel('sin', color='r')

(min_y, max_y) = ax2.get_ylim()
dist = (max_y - min_y) * 2.

ax2.set_ylim((min_y, max_y + dist))

yticklabels = ax2.get_yticklabels()
yticks = ax2.get_yticklines()

nlabels = len(yticklabels) / 2
nticks = len(yticks) / 2

for i in range(len(yticklabels)):
    if i < nlabels:
        yticklabels[i].set_color('r')
    else:
        yticklabels[i].set_visible(False)

for i in range(len(yticks)):
    if i < nticks:
        yticks[i].set_color('r')
    else:
        yticks[i].set_visible(False)

plt.show()

enter image description here

...