определить максимальное значение столбца для другого столбца в кадре данных pandas - PullRequest
0 голосов
/ 29 октября 2018

У меня есть датафрейм, содержащий идентификатор местоположения, название магазина и доход магазина. Я хочу определить магазин, который имеет максимальный доход на единицу площади

Я написал код для этого, но не уверен, есть ли лучший способ справиться с этим делом

import pandas as pd    
dframe=pd.DataFrame({"Loc_Id":[1,2,2,1,2,1,3,3],"Store":["A","B","C","B","D","B","A","C"],
                 "Revenue":[50,70,45,35,80,70,90,65]})

#group by location id, then save max per location in new column
dframe["max_value"]=dframe.groupby("Loc_Id")["Revenue"].transform(max)

#create new column by checking if the revenue equal to max revenue
dframe["is_loc_max"]=dframe.apply(lambda x: 1 if x["Revenue"]==x["max_value"] else 0,axis=1)

#drop the intermediate column 
dframe.drop(columns=["max_value"],inplace=True)

и это обязательный вывод: ![enter image description here

есть ли лучший способ получить этот вывод

1 Ответ

0 голосов
/ 29 октября 2018

Создать логическую маску путем сравнения с помощью eq (==) и преобразовать ее в integer s - 0, 1 в False, True:

s = dframe.groupby("Loc_Id")["Revenue"].transform('max')
dframe["max_value"]= s.eq(dframe["Revenue"]).astype(int)
print (dframe)
   Loc_Id Store  Revenue  max_value
0       1     A       50          0
1       2     B       70          0
2       2     C       45          0
3       1     B       35          0
4       2     D       80          1
5       1     B       70          1
6       3     A       90          1
7       3     C       65          0
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...