首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >熊猫栏填N/A用滚动平均数

熊猫栏填N/A用滚动平均数
EN

Stack Overflow用户
提问于 2021-12-30 01:01:18
回答 2查看 63关注 0票数 1

我有一只熊猫的数据

代码语言:javascript
复制
import pandas as pd
import numpy as np

df = pd.DataFrame({
                   'id': [1,2,3,4,5],
                   'rate': [0.5,0.4,0.5,np.nan,np.nan],
                  })

我想用前三个值的滚动平均值替换rate列中的NaNs。

预期产出:

EN

回答 2

Stack Overflow用户

发布于 2021-12-30 01:20:52

您可以尝试使用rolling替换isna()值。

代码语言:javascript
复制
df.loc[df.rate.isna(),'rate'] = df['rate'].rolling(3, min_periods=1).mean()
票数 1
EN

Stack Overflow用户

发布于 2021-12-30 02:12:28

试一试圆滚法,除了记住圆()的python行为,也就是the fact that most decimal fractions can’t be represented exactly as a float

代码语言:javascript
复制
df =df.assign(rate=np.where(df['rate'].isna(),round(df['rate'].rolling(3,1).mean(),1),df['rate']))
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70526485

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档