Как сбросить записи по количеству уникальных дней с помощью панд? - PullRequest
2 голосов
/ 09 ноября 2019

У меня есть фрейм данных, как показано ниже

df = pd.DataFrame({
'subject_id':[1,1,1,1,1,1,1,2,2,2,2,2],
'time_1' :['2173-04-03 12:35:00','2173-04-03 12:50:00','2173-04-05 12:59:00','2173-05-04 13:14:00','2173-05-05 13:37:00','2173-07-03 13:39:00','2173-07-04 11:30:00','2173-04-04 16:00:00','2173-04-09 22:00:00','2173-04-11 04:00:00','2173- 04-13 04:30:00','2173-04-14 08:00:00'],
 'val' :[5,5,5,5,1,6,5,5,8,3,4,6]})
df['time_1'] = pd.to_datetime(df['time_1'])
df['day'] = df['time_1'].dt.day
df['month'] = df['time_1'].dt.month

Я хотел бы удалить записи / предметы, у которых не более 4 or more уникальных дней

ЕслиВы видите мой примерный фрейм данных, вы можете видеть, что subject_id = 1 имеет только 3 уникальные даты, что составляет 3,4 and 5, поэтому я хотел бы полностью удалить subject_id = 1. Но если вы видите subject_id = 2, у него более 4 уникальных дат, например 4,9,11,13,14. Обратите внимание, что значения даты имеют метку времени, поэтому я извлекаю день из каждого поля даты и времени и проверяю наличие уникальных записей.

Это то, что я пытался

df.groupby(['subject_id','day']).transform('size')>4 # doesn't work
df[df.groupby(['subject_id','day'])['subject_id'].transform('size')>=4] # doesn't produce expected output

Я ожидаю, что мой вывод будет похожэто

enter image description here

1 Ответ

3 голосов
/ 09 ноября 2019

Измените свою функцию с size на DataFrameGroupBy.nunique, группируя только по столбцу subject_id:

df = df[df.groupby('subject_id')['day'].transform('nunique')>=4] 

Или, в качестве альтернативы, вы можете использовать фильтрация , но это должно быть медленнее, если вы используете больший размер или несколько уникальных групп:

df = df.groupby('subject_id').filter(lambda x: x['day'].nunique()>=4)

print (df)
    subject_id              time_1  val  day  month
7            2 2173-04-04 16:00:00    5    4      4
8            2 2173-04-09 22:00:00    8    9      4
9            2 2173-04-11 04:00:00    3   11      4
10           2 2173-04-13 04:30:00    4   13      4
11           2 2173-04-14 08:00:00    6   14      4
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...