我有python pandas dataframe
,其中一列包含月份名称。
如何使用字典进行自定义排序,例如:
custom_dict = {'March':0, 'April':1, 'Dec':3}
首先,将月份列设为分类,然后指定要使用的顺序。
In [21]: df['m'] = pd.Categorical(df['m'], ["March", "April", "Dec"])
In [22]: df # looks the same!
Out[22]:
a b m
0 1 2 March
1 5 6 Dec
2 3 4 April
现在,当你对月份列进行排序时,它将相对于该列表进行排序:
In [23]: df.sort_values("m")
Out[23]:
a b m
0 1 2 March
2 3 4 April
1 5 6 Dec
注意:如果值不在列表中,它将被转换为NaN。
对于那些有兴趣的人来说,是一个较旧的答案
你可以创建一个中间系列,并set_index在此基础上:
df = pd.DataFrame([[1, 2, 'March'],[5, 6, 'Dec'],[3, 4, 'April']], columns=['a','b','m'])
s = df['m'].apply(lambda x: {'March':0, 'April':1, 'Dec':3}[x])
s.sort_values()
In [4]: df.set_index(s.index).sort()
Out[4]:
a b m
0 1 2 March
1 3 4 April
2 5 6 Dec
如前所述,在新的熊猫中,Series可以replace更优雅地做到这一点:
s = df['m'].replace({'March':0, 'April':1, 'Dec':3})
稍有不同的是,如果字典之外没有值,则不会增加该值(它将保持不变)。
问题内容: 我有python pandas dataframe,其中一列包含月份名称。 如何使用字典进行自定义排序,例如: 问题答案: 熊猫0.15引入了“分类系列”,该分类系列提供了一种更清晰的方法: 首先,将月份列设为分类,然后指定要使用的顺序。 现在,当您对月份列进行排序时,它将相对于该列表进行排序: 注意:如果值不在列表中,它将被转换为NaN。 对于那些有兴趣的人来说,是一个较旧的答案。
问题内容: 我正在尝试通过降序对数据框进行排序。我在升序参数中输入了“ False”,但我的命令仍然在升序。 我的代码是: 但输出是 问题答案: 编辑:这已经过时,请参阅@Merlin的答案。 是非空 列表 ,与。您应该写:
问题内容: 我有以下数据框,我想先按“重要性”排序,然后再按“名称”排序: 我一直在努力做到这一点使用中提供了答案这个职位,但我不能得到它的工作。 最终结果应该是这样的 问题答案: 一种方法是使用自定义字典创建“等级”列,然后使用进行排序,然后在排序后删除该列:
问题内容: 我有一个像这样的数据框: 如你所见,月份不是按日历顺序排列的。因此,我创建了第二列以获取与每月(1-12)相对应的月份数。从那里,如何根据日历月的顺序对数据框进行排序? 问题答案: 用于按特定列的值对df进行排序: 如果要按两列排序,请将列标签列表传递给,并按排序优先级对列标签进行排序。如果使用,则结果将按列2然后按列排序。当然,对于这个示例,这实际上没有任何意义,因为其中的每个值都是
问题内容: 我有一个问题:这是由ElementTree库形成的列表列表。 word1..4可能包含Unicode字符,即(â,ü,ç)。 我想按我的自定义字母对列表列表进行排序。 我知道如何从这里按python中的单词对自定义字母进行排序 我也知道如何从此处http://wiki.python.org/moin/HowTo/Sorting按键排序 问题是我找不到如何应用这两种方法对“列表列表”进行
问题内容: 我想将稀疏矩阵(156060x11780)转换为数据帧,但出现内存错误,这是我的代码 我有一个问题 。我该如何解决? 问题答案: 尝试这个: 更新: 对于Pandas 0.20+,我们可以直接从稀疏数组构造: