a = [[0,0,0,0],[0,-1,1,0],[1,-1,1,0],[1,-1,1,0]]
df = pd.DataFrame(a, columns=['A','B','C','D'])
df
Output:
A B C D
0 0 0 0 0
1 0 -1 1 0
2 1 -1 1 0
3 1 -1 1 0
因此,每列垂直向下读取,列中的值都从第一行的 0 开始,一旦它们改变,它们就永远不会变回来,可以变成 1 或 -1。我想重新排列数据框列,以便按以下顺序排列:
- 尽可能对最早行中达到 1 的列进行排序
- 对最早行中命中 -1 的列进行排序
- 最后,剩余的行从未改变过值并保持为零(如果还有的话)
Desired Output:
C A B D
0 0 0 0 0
1 1 0 -1 0
2 1 1 -1 0
3 1 1 -1 0
我的主要数据框是 3000 行和 61 列长,有什么方法可以快速做到这一点?