繁体   English   中英

用列中的先前值填充数据框中的NaN值

[英]Fill NaN values in dataframe with previous values in column

嗨,我有一个数据框,例如缺少一些值:

在此处输入图片说明

黑色数字40和50是已经输入的值,红色数字是根据先前的值自动填充的。 第2行为空白,因为没有先前的数字可以填写。

知道如何有效地做到这一点吗? 我正在尝试循环,但也许有更好的方法

在熊猫fillna中 ,可以使用ffill方法轻松完成此操作

为了说明工作原理,请考虑以下示例数据框

df = pd.DataFrame()

df['Vals'] = [1, 2, 3, np.nan, np.nan, 6, 7, np.nan, 8]

    Vals
0   1.0
1   2.0
2   3.0
3   NaN
4   5.0
5   6.0
6   7.0
7   NaN
8   8.0

要填补缺失的值,请执行此操作

df['Vals'].fillna(method='ffill', inplace=True)

    Vals
0   1.0
1   2.0
2   3.0
3   3.0
4   3.0
5   6.0
6   7.0
7   7.0
8   8.0

有一个直接的同义词函数pandas.DataFrame.ffill

df['Vals',inplace=True]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM