我正在尝试绘制有关一个地区 5 个地区的特定行业的家庭收入部分的信息。
我使用 groupby 按地区对数据框中的信息进行排序:
df = df_orig.groupby('District')['Portion of income'].value_counts(dropna=False)
df = df.groupby('District').transform(lambda x: 100*x/sum(x))
df = df.drop(labels=math.nan, level=1)
ax = df.unstack().plot.bar(stacked=True, rot=0)
ax.set_ylim(ymax=100)
display(df.head())
District Portion of income
A <25% 12.121212
25 - 50% 9.090909
50 - 75% 7.070707
75 - 100% 2.020202
Run Code Online (Sandbox Code Playgroud)
由于此收入属于类别,因此我想以合乎逻辑的方式对堆叠条中的元素进行排序。Pandas 生成的图表如下。现在,顺序(从每个条形的底部开始)是:
我意识到这些是按字母顺序排序的,并且很好奇是否有办法设置自定义排序。为了直观,我希望顺序是(同样,从栏的底部开始):
然后,我想翻转图例以显示与此顺序相反的顺序(即,我希望图例顶部有 75 - 100,因为这将位于条形图的顶部)。