Cumsum reset at NaN

后端 未结 4 1400
醉话见心
醉话见心 2020-11-27 05:21

If I have a pandas.core.series.Series named ts of either 1\'s or NaN\'s like this:

3382   NaN
3381   NaN
...
3369   NaN
3368   NaN
         


        
4条回答
  •  生来不讨喜
    2020-11-27 06:22

    Even more pandas-onic way to do it:

    v = pd.Series([1., 3., 1., np.nan, 1., 1., 1., 1., np.nan, 1.])
    cumsum = v.cumsum().fillna(method='pad')
    reset = -cumsum[v.isnull()].diff().fillna(cumsum)
    result = v.where(v.notnull(), reset).cumsum()
    

    Contrary to the matlab code, this also works for values different from 1.

提交回复
热议问题