IIUC,以下;
创建列“ C”并填充nan
:
df['C'] = np.nan
计算'C_列中'降水'<0.04的连续出现:
def rolling_count(val):
if val < 0.04:
rolling_count.count +=1
else:
rolling_count.count = 0
return rolling_count.count
rolling_count.count = 0
df['C_'] = df['precipitation'].apply(rolling_count)
用“ 1”填充列“ C”,在其中找到第一个“ 4”,然后向后填充其他3:
df.loc[df[df['C_'] == 4].head(1).index.item(), 'C'] = 1
df['C'] = df['C'].fillna(method = 'bfill', limit = 3)
df['C'] = df['C'].fillna(0)
df['C'] = df['C'].astype(int)
df
temperature precipitation C C_
0 1.26 0.0279 0 1
1 1.64 0.0330 0 2
2 1.98 0.0381 0 3
3 2.31 0.0406 0 0
4 2.61 0.0406 0 0
5 2.89 0.0381 1 1
6 3.15 0.0356 1 2
7 3.51 0.0305 1 3
8 3.78 0.0305 1 4
9 3.78 0.0305 0 5
注意; 此结果与您的示例显示的结果不同,但是IIUC您需要找到低于0.04的4个连续行并填充“ C”。问题是您的“ C”中的“ 0.0406”值填充为“ 1”,且不低于0.04。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句