繁体   English   中英

按 Groupby 中的日期聚合 Pandas DataFrame 计数

[英]Aggregate Pandas DataFrame Counts by Dates in Groupby

我有一个 Pandas DataFrame ,其中包含第一个和最后一个日期列,我从中构建了一个dr字段,其中包含范围内的日期列表:

_id     FID     first_seen    last_seen     dr
607abc  1925    2020-11-13    2021-04-22    DatetimeIndex(['2020-11-13', '2020-11-14', '20...])
608abd  1925    2021-03-05    2021-03-07    DatetimeIndex(['2021-03-05', '2021-03-06', '20...])
442xae  1331    2020-05-05    2021-04-22    DatetimeIndex(['2020-05-05', '2021-04022', '20...])
...

对于每个FID ,对于与该 FID 相关联的每个日期,我需要获取该日期的_id计数。 例如,从上面,如下:

FID     date          count(_id)
1925    2020-11-13    44
1925    2020-11-14    46
...
1925    2021-04-22    61
1331    2020-05-05    189
1331    2020-05-06    190
...

我知道我需要先按 FID 分组,然后得到 first_seen 的最小值和 last_seen 的最大值,然后我就卡住了......

让我们尝试explode

df.explode('dr').groupby(['FID','dr']).size()

或者我们可以在这里尝试value_counts

df.explode('dr').value_counts(['FID','dr'])

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM