【问题标题】:Count consecutive number of ones in a pandas series计算熊猫系列中连续的个数
【发布时间】:2020-10-07 19:19:22
【问题描述】:

如果我有以下熊猫系列:

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

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

[2,1,2,3]

我怎样才能得到上面的输出?

【问题讨论】:

    标签: python pandas series


    【解决方案1】:

    让我们尝试使用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]
    

    【讨论】:

      【解决方案2】:

      以下应该有效:

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

      输出:

      [2, 1, 2, 3]
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2019-12-07
        • 1970-01-01
        • 1970-01-01
        • 2020-10-29
        • 2019-03-04
        • 2023-03-10
        • 1970-01-01
        • 2018-09-04
        相关资源
        最近更新 更多