Я пытаюсь заменить нулевые значения режимом чисел в каждой группе (групповая область). Есть ли в Пандах какой-нибудь более простой способ сделать это?
Я сделал это с помощью метода цикла, который не рекомендуется для очень больших наборов данных.
data = {'area':['abc', 'abc', 'abc', 'abc','bcd', 'bcd', 'bcd' ,
'cde','cde', 'cde', 'cde', 'cde'], 'number':[1, 2, 2, np.nan, 3, 3,
np.nan, 5, 5, 4, np.nan, np.nan]}
df = pd.DataFrame(data)
Hell = pd.DataFrame(df.groupby("area")['number'].agg(lambda
x:x.value_counts().index[0])).reset_index()
import math
for index in range(0,df.shape[0]):
if math.isnan(df['number'][index]):
for i in range(0,Hell.shape[0]):
if Hell['area'][i] == df['area'][index]:
df['number'][index] = Hell['number'][i]