gpt4 book ai didi

python - 第二列中值的条件累积计数

转载 作者:行者123 更新时间:2023-12-02 02:34:22 24 4
gpt4 key购买 nike

我想根据 KEY 列中的值在 flag 列中填充数字。

  • 如果 KEY 列中的值保持不变,我希望每两行填充相同的数字,而不是使用 cumcount() 来填充增量数字。
  • 如果 KEY 列中的值发生变化,填充的数字也会发生变化。

这是示例,df1 是我想要的 df0。

df0 = pd.DataFrame({'KEY':['0','0','0','0','1','1','1','2','2','2','2','2','3','3','3','3','3','3','4','5','6']})

df1 = pd.DataFrame({'KEY':['0','0','0','0','1','1','1','2','2','2','2','2','3','3','3','3','3','3','4','5','6'],
'flag':['0','0','1','1','2','2','3','4','4','5','5','6','7','7','8','8','9','9','10','11','12']})

最佳答案

您想要获取 cumcount 并加一。然后使用 %2 来区分奇数行或偶数行。然后,将累计和减1,从零开始计数。

您可以使用:

df0['flag'] = ((df0.groupby('KEY').cumcount() + 1) % 2).cumsum() - 1
df0
Out[1]:
KEY flag
0 0 0
1 0 0
2 0 1
3 0 1
4 1 2
5 1 2
6 1 3
7 2 4
8 2 4
9 2 5
10 2 5
11 2 6
12 3 7
13 3 7
14 3 8
15 3 8
16 3 9
17 3 9
18 4 10
19 5 11
20 6 12

关于python - 第二列中值的条件累积计数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64545116/

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