根据熊猫中的条件重置总和

发布于 2021-01-29 16:35:54

我的问题与小组中的“求和”非常相似,并根据熊猫熊猫的条件进行重置:基于附加条件的每个类别的求和,但由于我的条件要求,它们并不能使我到达那里。我有一个看起来像这样的数据框:

  TransactionId     Delta
          14          2
          14          3
          14          1
          14          2
          15          4
          15          2
          15          3

我想创建另一个列“累积”,该列为每个TransactionId计算Delta的总和。因此结果将如下所示:

  TransactionId     Delta    Cumulative
          14          2          2
          14          3          5
          14          1          6
          14          2          8
          15          4          4
          15          2          6
          15          3          9

我具有检查TransactionId相等性设置的条件:

c1 = df.TransactionId.eq(df.TransactionId.shift())

但是我不知道如何将Delta值添加到上一个“累积行”中。

关注者
0
被浏览
43
1 个回答
  • 面试哥
    面试哥 2021-01-29
    为面试而生,有面试问题,就找面试哥。

    用途groupby.cumsum

    df['Cumulative'] = df.groupby('TransactionId')['Delta'].cumsum()
    
    print (df)
    
      TransactionId  Delta  Cumulative
    0       14         2       2
    1       14         3       5
    2       14         1       6
    3       14         2       8
    4       15         4       4 
    5       15         2       6 
    6       15         3       9
    


知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看