python pandas版本_python-Pandas版本之间的MultiIndex / Reshaping差异

我有一个使用以下代码的DataFrame:

import pandas as pd

import numpy as np

index = pd.DatetimeIndex(['2017-05-04', '2017-05-05', '2017-05-08', '2017-05-09',

'2017-05-10'], dtype='datetime64[ns]',name = 'date', freq='B')

columns = pd.MultiIndex(levels=[['HSBA LN Equity', 'UCG IM Equity', 'ISP IM Equity'], ['LAST PRICE', 'HIGH', 'LOW']],

labels=[[0, 0, 0, 1, 1, 1, 2, 2, 2], [0, 1, 2, 0, 1, 2, 0, 1, 2]])

data = np.array([[ 663.8, 672.5, 661.1, 15.97, 16.02, 15.49, 2.76, 2.768, 2.694],

[ 658.6, 663.9, 656.0, 16.22, 16.48, 15.77, 2.842, 2.868, 2.77 ],

[ 660.6, 664.1, 658.9, 16.01, 16.49, 15.94, 2.852, 2.898, 2.826],

[ 664.9, 669.2, 662.5, 15.90, 16.41, 15.90, 2.848, 2.898, 2.842],

[ 670.9, 673.4, 663.8, 16.09, 16.15, 15.59, 2.85, 2.888, 2.802]])

df = pd.DataFrame(data, columns=columns, index = index)

输出看起来像这样:

HSBA LN Equity UCG IM Equity \n LAST PRICE HIGH LOW LAST PRICE HIGH LOW

date

2017-05-04 663.8 672.5 661.1 15.97 16.02 15.49

2017-05-05 658.6 663.9 656.0 16.22 16.48 15.77

2017-05-08 660.6 664.1 658.9 16.01 16.49 15.94

2017-05-09 664.9 669.2 662.5 15.90 16.41 15.90

2017-05-10 670.9 673.4 663.8 16.09 16.15 15.59

ISP IM Equity

LAST PRICE HIGH LOW

date

2017-05-04 2.760 2.768 2.694

2017-05-05 2.842 2.868 2.770

2017-05-08 2.852 2.898 2.826

2017-05-09 2.848 2.898 2.842

2017-05-10 2.850 2.888 2.802

由于当我使用df = df.stack(0)时从0.19.2升级到Pandas 0.20.1,因此输出如下所示:

HIGH LAST PRICE LOW

date

2017-05-04 HSBA LN Equity 672.500 663.800 661.100

UCG IM Equity 2.768 2.760 2.694

ISP IM Equity 16.020 15.970 15.490

2017-05-05 HSBA LN Equity 663.900 658.600 656.000

UCG IM Equity 2.868 2.842 2.770

ISP IM Equity 16.480 16.220 15.770

2017-05-08 HSBA LN Equity 664.100 660.600 658.900

UCG IM Equity 2.898 2.852 2.826

ISP IM Equity 16.490 16.010 15.940

2017-05-09 HSBA LN Equity 669.200 664.900 662.500

UCG IM Equity 2.898 2.848 2.842

ISP IM Equity 16.410 15.900 15.900

2017-05-10 HSBA LN Equity 673.400 670.900 663.800

UCG IM Equity 2.888 2.850 2.802

ISP IM Equity 16.150 16.090 15.590

列已更改顺序,股票价格不再与正确的股票代码匹配.

这是错误吗?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值