小编pri*_*mo7的帖子

计算连续几天的python数据帧

我正在尝试按连续日期对ID进行分组.

ID     Date   
abc    2017-01-07  
abc    2017-01-08  
abc    2017-01-09  
abc    2017-12-09  
xyz    2017-01-05  
xyz    2017-01-06 
xyz    2017-04-15  
xyz    2017-04-16 
Run Code Online (Sandbox Code Playgroud)

需要退货:

ID     Count
abc    3
abc    1
xyz    2
xyz    2
Run Code Online (Sandbox Code Playgroud)

我试过了:

d = {'ID': ['abc', 'abc', 'abc', 'abc', 'xyz', 'xyz', 'xyz', 'xyz'], 'Date': ['2017-01-07','2017-01-08', '2017-01-09', '2017-12-09', '2017-01-05', '2017-01-06', '2017-04-15', '2017-04-16']}
df = pd.DataFrame(data=d)
df['Date'] =  pd.to_datetime(df['Date'])

today = pd.to_datetime('2018-10-23')   
x = df.sort_values('Date', ascending=0)
g = x.groupby(['ID'])
x[(today - x['Date']).dt.days == g.cumcount()].groupby(['ID']).size()
Run Code Online (Sandbox Code Playgroud)

是否有一种简单的方法可以通过ID获取所有日期范围的计数?

python pandas pandas-groupby

4
推荐指数
1
解决办法
661
查看次数

标签 统计

pandas ×1

pandas-groupby ×1

python ×1