У меня есть рабочий код следующим образом:
active_parking = pd.pivot_table(parking[parking['Bldg Status'] == 'ACTIVE'],
index='Owned/Leased',
values='Total Parking Spaces',
aggfunc='mean'
)
active_parking['% of Total'] = ((active_parking['Total Parking Spaces'] / active_parking['Total Parking Spaces'].sum()) * 100)
print(active_parking, '\n')
active_parking.plot(kind='bar')
for i, number in enumerate(active_parking['Total Parking Spaces']):
plt.text(x=i, y=number, s=number, horizontalalignment='center', weight='bold')
for i, number in enumerate(active_parking['% of Total']):
plt.text(x=i, y=number, s=number, horizontalalignment='left', weight='bold')
plt.xticks(rotation=0)
plt.show()
И он выводит:
Total Parking Spaces % of Total
Owned/Leased
LEASED 44.707349 37.546059
OWNED 74.365997 62.453941
Но у моего графика есть две проблемы, которые я не могу решить:
1) I want the displayed value on top of each bar limited to two decimal places.
2) After solving the above issue, how do I center the value over each bar?
![enter image description here](https://i.stack.imgur.com/jBmKC.png)
Даже если я обрежу отображение текста с помощью этого: pd.options.display.float_format = '{: .2f}'. Format , сюжет по-прежнему показывает 14 знаков после запятой.