3

我正在尝试在某些条件适用的情况下用 0 填充一些行。我正在努力:

df.loc[:,(df.Available == True) & (df.Intensity.isnull())].Intensity = df.loc[(df.Available == True) & (df.Intensity.isnull())].Intensity.fillna(0, inplace=True)

这不起作用 bc IndexingError: Unalignable boolean Series key provided,但是当我尝试时

df.loc[(df.Available == True) & (df.Intensity.isnull())].Intensity = df.loc[(df.Available == True) & (df.Intensity.isnull())].Intensity.fillna(0, inplace=True)

这注册为更新副本。我怎样才能做到这一点?谢谢!

4

3 回答 3

7

fillna如果您已经在处理 Intensity 为空的行,我认为您甚至不需要。

df.loc[(df.Available) & (df.Intensity.isnull()), 'Intensity'] = 0

或者你可以做

df.loc[df.Available, 'Intensity'] = df.loc[df.Available, 'Intensity'].fillna(0)
于 2017-04-11T17:23:42.970 回答
2

国际大学联盟:

df.query('Available == True')['Intensity'].fillna(0)
于 2017-04-11T17:21:50.433 回答
2

为了便于阅读,我把它分成了几行

a = df.Available == True
b = df.Intensity.isnull()
df.loc[(a & b), 'Intensity'] = 0

但是,这也应该有效

a = df.Available == True
b = df.Intensity.isnull()
df.Intesity *= (a & b)
于 2017-04-11T17:21:59.593 回答