pandas 使用 resample/timedelta 在线记录

pandas online logging with resample/timedelta

我有用户登录和注销的日志。我想创建一个日志,显示特定用户在特定十五分钟内是否在线 window。

pandas 有不同的日期时间索引选项(date_range、period_range),但我使用的是 pd.date_range(start, stop, freq) 之类的东西,但我不知道在哪里做从那里。

这是数据:

user    start                      stop
Alice   2017-10-02 08:59:40-04:00   2017-10-02 09:25:49-04:00
Joe     2017-10-02 08:59:45-04:00   2017-10-02 10:45:11-04:00
Bob     2017-10-02 09:16:06-04:00   2017-10-02 10:05:53-04:00

这是我需要的(0 离线,1 在线):

period            Alice Joe Bob
2017-10-02 09:00  1     1   0
2017-10-02 09:15  1     1   1
2017-10-02 09:30  0     1   1

这是一种方法。首先为每个 user/time:

创建一个 empty/zeroed DataFrame
In [11]: res = pd.DataFrame({name: 0 for name in df["user"].unique()}, pd.date_range("2017-10-02 09:00", "2017-10-02 11:00", freq="15T"))

In [12]: res
Out[12]:
                     Alice  Bob  Joe
2017-10-02 09:00:00      0    0    0
2017-10-02 09:15:00      0    0    0
2017-10-02 09:30:00      0    0    0
2017-10-02 09:45:00      0    0    0
2017-10-02 10:00:00      0    0    0
2017-10-02 10:15:00      0    0    0
2017-10-02 10:30:00      0    0    0
2017-10-02 10:45:00      0    0    0
2017-10-02 11:00:00      0    0    0

现在填写 in/set 用户登录的时间:

In [13]: for _, row in df.iterrows():
     ...:     res.loc[row["start"]:row["stop"], row["user"]] = 1
     ...:

In [14]: res
Out[14]:
                     Alice  Bob  Joe
2017-10-02 09:00:00      1    0    1
2017-10-02 09:15:00      1    0    1
2017-10-02 09:30:00      0    1    1
2017-10-02 09:45:00      0    1    1
2017-10-02 10:00:00      0    1    1
2017-10-02 10:15:00      0    0    1
2017-10-02 10:30:00      0    0    1
2017-10-02 10:45:00      0    0    1
2017-10-02 11:00:00      0    0    0