415

我有dataframe超过 200 列。问题是它们生成的顺序是

['Q1.3','Q6.1','Q1.2','Q1.1',......]

我需要按如下方式对列进行排序:

['Q1.1','Q1.2','Q1.3',.....'Q6.1',......]

我有什么方法可以在 Python 中做到这一点吗?

4

11 回答 11

532
df = df.reindex(sorted(df.columns), axis=1)

这假定对列名进行排序将给出您想要的顺序。如果您的列名不会按字典顺序排序(例如,如果您希望列 Q10.3 出现在 Q9.1 之后),您需要进行不同的排序,但这与 pandas 无关。

于 2012-06-16T21:12:21.780 回答
405

你还可以做的更简洁:

df.sort_index(axis=1)

确保将结果分配回去:

df = df.sort_index(axis=1)

或者,就地执行:

df.sort_index(axis=1, inplace=True)
于 2012-07-08T18:56:47.510 回答
53

你可以这样做:

df[排序(df.columns)]

编辑:较短的是

df[sorted(df)]
于 2014-06-24T21:22:45.420 回答
26

Tweet 的答案可以传递给上面的 BrenBarn 的答案

data.reindex_axis(sorted(data.columns, key=lambda x: float(x[1:])), axis=1)

因此,对于您的示例,请说:

vals = randint(low=16, high=80, size=25).reshape(5,5)
cols = ['Q1.3', 'Q6.1', 'Q1.2', 'Q9.1', 'Q10.2']
data = DataFrame(vals, columns = cols)

你得到:

data

    Q1.3    Q6.1    Q1.2    Q9.1    Q10.2
0   73      29      63      51      72
1   61      29      32      68      57
2   36      49      76      18      37
3   63      61      51      30      31
4   36      66      71      24      77

然后做:

data.reindex_axis(sorted(data.columns, key=lambda x: float(x[1:])), axis=1)

导致:

data


     Q1.2    Q1.3    Q6.1    Q9.1    Q10.2
0    2       0       1       3       4
1    7       5       6       8       9
2    2       0       1       3       4
3    2       0       1       3       4
4    2       0       1       3       4
于 2013-10-08T02:22:08.443 回答
25

对于几列,您可以将列按您想要的顺序排列:

#['A', 'B', 'C'] <-this is your columns order
df = df[['C', 'B', 'A']]

此示例显示排序和切片列:

d = {'col1':[1, 2, 3], 'col2':[4, 5, 6], 'col3':[7, 8, 9], 'col4':[17, 18, 19]}
df = pandas.DataFrame(d)

你得到:

col1  col2  col3  col4
 1     4     7    17
 2     5     8    18
 3     6     9    19

然后做:

df = df[['col3', 'col2', 'col1']]

导致:

col3  col2  col1
7     4     1
8     5     2
9     6     3     
于 2016-03-11T05:54:35.027 回答
18

如果你需要一个任意序列而不是排序序列,你可以这样做:

sequence = ['Q1.1','Q1.2','Q1.3',.....'Q6.1',......]
your_dataframe = your_dataframe.reindex(columns=sequence)

我在 2.7.10 中对此进行了测试,它对我有用。

于 2015-11-05T21:48:39.667 回答
16

不要忘记在 Wes 的答案中添加“inplace=True”或将结果设置为新的 DataFrame。

df.sort_index(axis=1, inplace=True)
于 2014-12-08T15:33:31.697 回答
4

最快的方法是:

df.sort_index(axis=1)

请注意,这会创建一个新实例。因此,您需要将结果存储在一个新变量中:

sortedDf=df.sort_index(axis=1)
于 2015-01-29T12:37:26.447 回答
1

sort方法和sorted函数允许您提供自定义函数来提取用于比较的键:

>>> ls = ['Q1.3', 'Q6.1', 'Q1.2']
>>> sorted(ls, key=lambda x: float(x[1:]))
['Q1.2', 'Q1.3', 'Q6.1']
于 2012-06-16T21:14:20.077 回答
1

一个用例是您已使用某些前缀命名(某些)列,并且您希望使用这些前缀以某种特定顺序(非字母顺序)对列进行排序。

例如,您可能会以 开始所有功能Ft_,以 等开始标签Lbl_,并且您首先需要所有不带前缀的列,然后是所有功能,然后是标签。您可以使用以下函数来执行此操作(我会注意到sum用于减少列表的可能的效率问题,但这不是问题,除非您有很多列,而我没有):

def sortedcols(df, groups = ['Ft_', 'Lbl_'] ):
    return df[ sum([list(filter(re.compile(r).search, list(df.columns).copy())) for r in (lambda l: ['^(?!(%s))' % '|'.join(l)] + ['^%s' % i  for i in l ] )(groups)   ], [])  ]
于 2017-07-24T09:43:43.147 回答
-2
print df.sort_index(by='Frequency',ascending=False)

其中 by 是列的名称,如果要根据列对数据集进行排序

于 2015-06-20T19:58:40.727 回答