Python,如何使用字典填充数据框中的空值

Python, how to fill nulls in a data frame using a dictionary

我有一个像这样的数据框 df

A     B      C
1     'x'    15.0
2     'y'    NA
3     'z'    25.0

和字典 dc 之类的东西

dc = {'x':15,'y':35,'z':25}

我想使用字典中 B 列的值填充数据框 C 列中的所有空值。这样我的数据框就会变成

A     B      C
1     'x'    15
2     'y'    35
3     'z'    25

有人可以帮我怎么做吗?

谢谢, 马诺杰

df['C'] = np.where(df['C'].isnull(), df['B'].apply(lambda x: dc[x]), df['C'])

您可以使用 fillna with map:

dc = {'x':15,'y':35,'z':25}

df['C'] = df.C.fillna(df.B.map(dc))
df
#   A   B      C
#0  1   x   15.0
#1  2   y   35.0
#2  3   z   25.0