12

如何订购我的条形图,使其按从最大值到最小值的顺序排列?我尝试了下面的代码,但它没有给我预期的结果。

我希望条形按“b”、“a”、“c”排序(按计数)

df = pd.DataFrame([['a',2],['a',3],['b',4],['b',5],['b',4],['c',8]], columns=['Letters', 'Numbers'])

Letters Numbers
0   a   2
1   a   3
2   b   4
3   b   5
4   b   4
5   c   8

alt.Chart(df).mark_bar().encode(
   alt.X('Letters:N'),
   alt.Y('count():Q', sort=alt.EncodingSortField(field='count', op='count', order='ascending')))

输出图表

4

2 回答 2

16

排序关键字需要应用于被排序的轴 - 这里是 X 轴。

alt.Chart(df).mark_bar().encode(
   alt.X('Letters:N', sort=alt.EncodingSortField(field="Letters", op="count", order='ascending')),
   alt.Y('count():Q'))
于 2018-10-18T16:43:16.993 回答
2

简单的替代方法,指定您要排序的频道:

alt.Chart(df).mark_bar().encode(
   alt.X('Letters:N', sort='-y'),
   alt.Y('count():Q'))

文档

于 2022-01-10T14:52:54.563 回答