[英]plot percent bar in seaborn from dataframe
我有一個數據框,看起來像:
|---------------------|------------------|------------------|
| Gender | Male | Female |
|---------------------|------------------|------------------|
| Scenario | | |
|---------------------|------------------|------------------|
| A | 79 | 217 |
|---------------------|------------------|------------------|
| B | 59 | 408 |
|---------------------|------------------|------------------|
| C | 420 | 330 |
|---------------------|------------------|------------------|
| D | 208 | 1330 |
我想繪制一個海洋百分比的條形圖,它應該是一個代表女性百分比的條形,即對於場景A,該條形應顯示217 /(217 + 79),依此類推。 我怎樣才能做到這一點。 我可以從以下代碼中繪制堆疊的條形圖或並排條形圖。
stacked = my_dataframe.stack().reset_index().rename(columns={0:'value'})
# plot grouped bar chart
sns.barplot(x=stacked.Scenario, y=stacked.value, hue=stacked.Gender)
plt.show()
不是我最優雅的代碼,但這可行:
import pandas as pd
stacked = pd.DataFrame({'Scenario': list('ABCD'), 'Male': [79, 59, 420, 208], 'Female': [217, 408, 330, 1330]})
pd.DataFrame(stacked.apply(lambda x: {'Scenario': x.Scenario, 'Male_pct': x.Male / (x.Male + x.Female), 'Female_pct': x.Female / (x.Male + x.Female)}, axis=1,).tolist())
然后將其繪制成您已經繪制的樣子。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.