为什么 groupby 和rolling 不能一起工作?

2024-01-15

我有一个从 coinmarketcap 中抓取的 df 。我正在尝试计算 close_price 列的波动率指标,但是当我使用 groupby 时,我收到一条错误消息:

final_coin_data['vol'] = final_coin_data.groupby('coin_name')['close_price'].rolling(window=30).std()
TypeError: incompatible index of inserted column with frame index

df 结构(加载 CSV 后出现“Unnamed:0”):

    Unnamed: 0  close_price coin_name   date            high_price  low_price    market_cap         open_price  volume
0   1           9578.63     Bitcoin     Mar 11, 2018    9711.89     8607.12      149,716,000,000    8852.78     6,296,370,000
1   2           8866.00     Bitcoin     Mar 10, 2018    9531.32     8828.47      158,119,000,000    9350.59     5,386,320,000
2   3           9337.55     Bitcoin     Mar 09, 2018    9466.35     8513.03      159,185,000,000    9414.69     8,704,190,000
3   1           9578.63     Monero      Mar 11, 2018    9711.89     8607.12      149,716,000,000    8852.78     6,296,370,000
4   2           8866.00     Monero      Mar 10, 2018    9531.32     8828.47      158,119,000,000    9350.59     5,386,320,000
5   3           9337.55     Monero      Mar 09, 2018    9466.35     8513.03      159,185,000,000    9414.69     8,704,190,000

(忽略不正确的价格,这是df的基础)

当使用以下代码时:

final_coin_data1['vol'] = final_coin_data.groupby('coin_name')['close_price'].rolling(window=30).std().reset_index(0,drop=True)

我遇到了内存错误。我认为我正确使用了 groupby 。如果我取出final_coin_data1['vol'] =然后我得到一个看起来正确的系列,但它不允许我插入回 df.

当我第一次开始这个项目时。我只有 1 个硬币,并使用下面的代码,它计算出的波动性没有问题。

 final_coin_data1['vol'] = final_coin_data['close_price'].rolling(window=30).std()

当我运行这个时,

final_coin_data['close_price'].rolling(window=30).std()

生成索引列和结果列。当我尝试合并回原始 df 作为新列时final_coin_data1['vol']我收到一个错误TypeError: incompatible index of inserted column with frame index所以为了纠正这个问题,我reset_index(drop=True)然后这消除了允许将结果连接到的索引final_coin_data1['vol'].

最终的功能代码如下所示:

final_coin_data1['vol'] = final_coin_data.groupby('coin_name')['close_price'].rolling(window=30).std().reset_index(0,drop=True)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

为什么 groupby 和rolling 不能一起工作? 的相关文章

随机推荐