Я новичок в Python и учусь на этом языке.Я искал решение этой проблемы на прошлой неделе, но не смог.
У меня есть гистограмма с горизонтальной укладкой, которую я не могу заставить надписи правильно разместить.
import matplotlib.pyplot as plt
import matplotlib.patches as mpatches
import numpy as np
plt.rcParams['figure.figsize'] = 25,12
fig = plt.figure()
ax = plt.subplot()
respond = [2, 19, 46, 46, 55, 61, 78, 121, 150, 158, 169]
no_response = [0, 3, 51, 70, 32, 19, 61, 81, 109, 105, 132]
y = np.arange(len(respond))
plt.barh(y, respond, color='teal')
plt.barh(y, no_response, color='brown', left=respond)
y_labels = ['label_1', 'Label_2', 'Label_3', 'Label_4', 'Label_5',
'Label_6', 'Label_7', 'Label_8', 'Label_9', 'Label_10',
'Label_11']
plt.yticks(y, y_labels)
plt.title('MASS Responses by Group')
plt.xlabel('Responses')
plt.ylabel('GD Group')
responding = mpatches.Patch(color='teal', label='Responded')
not_responding = mpatches.Patch(color='brown', label='No Response')
plt.legend(handles=[responding, not_responding], loc='lower right')
rects = ax.patches
# For each bar: Place a label
for rect in rects:
# Get X and Y placement of label from rect.
x_value = rect.get_width()
y_value = rect.get_y() + rect.get_height()/2.5
# Number of points between bar and label. Change to your liking.
space = 25
# Vertical alignment for positive values
ha = 'center'
# If value of bar is negative: Place label left of bar
if x_value < 0:
# Invert space to place label to the left
space *= -1
# Horizontally align label at right
ha = 'center'
# Use X value as label and format number with one decimal place
label = "{:.0f}".format(x_value)
# Create annotation
ax.annotate(
label, # Use `label` as label
(x_value, y_value), # Place label at end of the bar
xytext=(space, 0), # Horizontally shift label by `space`
textcoords="offset points", # Interpret `xytext` as offset in points
va='baseline', # Vertically center label
ha='center', # Horizontally align label differently
for positive and negative values.
color='white', # Font color of the label
fontweight='bold') # Bolded
#fig.savefig('test.png', bbox_inches='tight', pad_inches=2)
plt.show()
Когда вы запускаете диаграмму, вы можете видеть, что значения выровнены относительноЗначение оси XМне нужно, чтобы они совпали с соответствующими прямоугольниками.