首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Python Dataframe计算具有不同TimeStamp的行之间的TimeDifference

Python Dataframe计算具有不同TimeStamp的行之间的TimeDifference
EN

Stack Overflow用户
提问于 2019-09-16 21:29:11
回答 1查看 64关注 0票数 0

我想确定Python Pandas DataFrame中不同行之间的增量时间。几行可以有相同的时间戳。然后,增量时间应该是指最后一个不同的时间。

例如:

代码语言:javascript
复制
   row-Number | timestamp  | expected DeltaTime
       0      |     0      |         0
       1      |    13      |         13
       2      |    13      |         13
       3      |    25      |         12
       4      |    25      |         12    
       5      |    25      |         12   

我使用的是:

代码语言:javascript
复制
df['delta_time_diff'] = (df['timestamp'] - df['timestamp'].shift()).fillna(0)

但是,我只能参考最后一行,它可能不会给我提供所需的值。对于长DataFrames,使用for循环的计算太耗时。

任何帮助都将不胜感激。提前谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-09-16 21:44:33

这里有一种方法:

代码语言:javascript
复制
s = df['timestamp'].eq(df.timestamp.shift())
df['expected DeltaTime'] = df['timestamp'].diff().mask(s).ffill()

输出(第一个时间戳不同,可以通过fillna修复):

代码语言:javascript
复制
   row-Number  timestamp  expected DeltaTime
0           0          0                 NaN
1           1         13                13.0
2           2         13                13.0
3           3         25                12.0
4           4         25                12.0
5           5         25                12.0
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57957934

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档