2017-09-15 71 views
8

Próbuję zrobić "polarną" fabułę sypdera, ale mam pewne problemy z etykietami osi. Labity xaxis zawsze wydają się kończyć na warstwie poniżej siatki osi y (litery są pokryte linią siatki, jak pokazano na rysunku poniżej), chciałbym je na górze.Etykieta osi ukryta za pomocą osi w wątku?

Próbowałem ustawić zorders, ale bez powodzenia. Jeśli ustawię zord dla wykreślonych linii powyżej 2, przechodzą one na górę (pod względem warstwy) osi i siatki ... ale nadal chcę, aby etykiety były widoczne na górze wykresu. Jeśli ustawię je poniżej 2 linie podążają poniżej siatki. Ustawienie zordu siatki lub etykiet kleszczowych nie wydaje się mieć żadnego efektu.

Oto moja próba: jak widać czerwone linie siatki kończą się na górze tekstu "przemysł", podczas gdy szara linia siatki pozostaje poniżej. Chciałbym „przemysłu”, aby być na szczycie obu linii i działek

import matplotlib.pyplot as plt 
import numpy as np 
import pandas as pd 
import random 

data = random.sample(range(100), 5) 
data[0] = 100 
data[3] = 50 
index = ['industry', 'residential', 'agriculture', 'transport', 'other'] 
df1 = pd.DataFrame(data, index=index, columns=['data']) 
df2 = pd.DataFrame(np.array(data)/2, index=index, columns=['data']) 

fig = plt.figure() 

ax = fig.add_subplot(111, projection="polar") 

ax.grid(True) 
ax.yaxis.grid(color='r') 
ax.xaxis.grid(color='#dddddd') 

for spine in ax.spines.values(): 
    spine.set_edgecolor('None') 

theta = np.arange(len(df1))/float(len(df1))*2.*np.pi 

l1, = ax.plot(theta, df1["data"], color="gold", marker="o", label=None, zorder=1) # , zorder = -3) 
l2, = ax.plot(theta, df2["data"], color='tomato', marker="o", label=None, zorder=1.1) #, zorder =-2) 

def _closeline(line): 
    x, y = line.get_data() 
    x = np.concatenate((x, [x[0]])) 
    y = np.concatenate((y, [y[0]])) 
    line.set_data(x, y) 
[_closeline(l) for l in [l1, l2]] 

ax.fill(theta, df1["data"], "gold", alpha=1, zorder=1) 
ax.fill(theta, df2["data"], 'tomato', alpha=1, zorder=1.1) 

ax.set_rlabel_position(216) 
ax.set_xticks(theta) 
ax.set_xticklabels(df2.index, fontsize=12)#, zorder=1) 

legend = plt.legend(handles=[l1,l2], labels =['first','second'], loc='lower right') 

plt.title("data [unit]", fontsize = 16, y = 1.2) 


plt.savefig('atlas//trial2.png', bbox_inches='tight', dpi = 300) 
plt.show() 

Here is my attempt: as you can see the red lines of the grid end up on top of the text 'industry' while the gray line of the grid stays below. I would like 'industry' to be on top of both line and of the plots

+1

Próbowałem kilka kombinacji 'zorder's które powinny mieć wpływ na twój problem, na próżno. Może to być błąd podobny do tego (https://github.com/matplotlib/matplotlib/issues/5045). Polarne wątki zawsze wydają się nieco bardziej problematyczne niż kartezjańskie. Kudos za dobrze sformułowane pytanie w komplecie z działającym przykładem! –

Odpowiedz

0

Cóż, to rozwiązuje mój problem, chociaż nie jest to miłe odpowiedź.

W powyższym skrypcie zastępuję ax.set_xticklabels(df2.index, fontsize=12) poniższymi słowami, aby zastąpić etykiety osi równoważnym tekstem.

for it in np.arange(len(theta)): 
    txt = ax.text(theta[it], maxy*1.1, index[it], va = 'center', ha = 'center', fontsize = 12) 

ax.set_xticklabels('') 

"Etykiety" znajdują się teraz nad osią i kratkami.

+0

Jeśli przyjmiesz swoją odpowiedź, gdy otrzyma nagrodę, nie możesz zmotywować innych, aby już teraz patrzyli na tę kwestię, ponieważ widzą, że to pytanie już zostało zaakceptowane. – ImportanceOfBeingErnest

+0

usunięto podziękowania, właśnie testowałem, czy mam odzyskać punkty :) – esperluette

+0

Nie, punkty zostaną utracone, jeśli przyjmiesz własną odpowiedź. Jeśli akceptujesz czyjąś odpowiedź, zostanie im nagrodzona. – ImportanceOfBeingErnest