我有一个形状像这样的数据框:
PX_LAST PX_OPEN PX_CLOSE ticker source timestamp
0 1 2 3 A LSE 20180101
1 4 5 6 A LSE 20180102
1 7 8 9 B LSE 20180101
1 10 11 12 B LSE 20180102
....
我想将其按摩为以下格式:
A B
LSE LSE
PX_LAST, PX_CLOSE, PX_OPEN PX_LAST, PX_CLOSE, PX_OPEN
timestamp
20180101 1 2 3 7 8 9
20180102 4 5 6 10 11 12
....
我尝试首先使用set_index将股票行情和源列设置为行索引并使用unstack将它们推到列轴上,这似乎确实有效
df.set_index(['timestamp', 'ticker', 'source'])
.unstack(level=[1,2])
.swaplevel(0,1,axis=1)
.swaplevel(1,2,axis=1)
这可以解决问题,但有两个问题:1)它非常冗长,我们需要执行所有交换级别调用才能使列成为正确的形状。2)它似乎没有按照我希望的方式进行分组,即我得到的结果是这样的:
LSE LSE LSE LSE ...
PX_LAST PX_LAST PX_CLOSE PX_CLOSE ...
timestamp
20180101 1 7 2 8 ...
20180102 4 8 5 11 ...
有没有更简洁的方法来做到这一点,这样我就可以获得我想要的格式?
临摹微笑
蓝山帝景
收到一只叮咚
相关分类