阅读以下内容后:http://pandas.pydata.org/pandas-docs/version/0.13.1/generated/pandas.DataFrame.sort.html
我仍然无法弄清如何按自定义列表对列进行排序。显然, 默认的排序是按字母顺序排列的。 我来举个例子。 这是我的(非常简略的)数据框:
Player Year Age Tm G
2967 Cedric Hunter 1991 27 CHH 6
5335 Maurice Baker 2004 25 VAN 7
13950 Ratko Varda 2001 22 TOT 60
6141 Ryan Bowen 2009 34 OKC 52
6169 Adrian Caldwell 1997 31 DAL 81
我希望能够按照球员、年份和队伍进行排序。球员和年份默认按正常顺序排序对我来说已经可以了。但是,我不想按字母顺序排序队伍,因为我希望TOT总是排在最前面。
以下是我创建的列表:
sorter = ['TOT', 'ATL', 'BOS', 'BRK', 'CHA', 'CHH', 'CHI', 'CLE', 'DAL', 'DEN',
'DET', 'GSW', 'HOU', 'IND', 'LAC', 'LAL', 'MEM', 'MIA', 'MIL',
'MIN', 'NJN', 'NOH', 'NOK', 'NOP', 'NYK', 'OKC', 'ORL', 'PHI',
'PHO', 'POR', 'SAC', 'SAS', 'SEA', 'TOR', 'UTA', 'VAN',
'WAS', 'WSB']
阅读了上面的链接后,我认为这个方法会起作用,但实际上并没有:
df.sort(['Player', 'Year', 'Tm'], ascending = [True, True, sorter])
它仍然在顶部有ATL的标识,这意味着它是按照字母顺序排序而不是按照我的自定义列表排序。任何帮助都将不胜感激,我真的想不出怎么解决这个问题。
value_counts()
有些相关:https://dev59.com/ylcP5IYBdhLWcg3wxMw5。 - Skippy le Grand Gourou