gpt4 book ai didi

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

转载 作者:太空宇宙 更新时间:2023-11-03 15:47:19 27 4
gpt4 key购买 nike

我有一个从 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 结构('Unnamed:0' 在我加载我的 CSV 之后出现):

    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)

关于python - 为什么 groupby 和 rolling 不能一起工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49245918/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com