计算熊猫系列中的连续个数

时间:2020-10-07 19:19:22

标签: python pandas series

如果我有以下熊猫系列:

import pandas as pd
s = pd.Series([0,1,1,0,1,0,0,1,1,0,1,1,1])

我想要一个连续的计数列表,在这种情况下,所需的输出是

[2,1,2,3]

如何获得以上输出?

2 个答案:

答案 0 :(得分:5)

让我们尝试使用cumsum创建新密钥

s[s==1].groupby(s.eq(0).cumsum()).sum()
1    2
2    1
4    2
5    3
dtype: int64

#s[s == 1].groupby(s.eq(0).cumsum()).sum().tolist()
#[2, 1, 2, 3]

答案 1 :(得分:1)

以下方法应该起作用:

[len(i) for i in ''.join([str(i) for i in list(s)]).split('0') if '1' in i]

输出:

[2, 1, 2, 3]