为了账号安全,请及时绑定邮箱和手机立即绑定

找出两行之间经过了多少时间(数据时间)

找出两行之间经过了多少时间(数据时间)

慕神8447489 2022-11-01 14:03:51
Subject.iloc[1, 0]  is equal to datetime.time(13, 16, 14, 336000)和Subject.iloc[2, 0]  is equal to datetime.time(13, 16, 14, 338000)我要做的就是找到从 Subject.iloc[1, 0] 到 Subject.iloc[2, 0] 的经过时间。但是当我减去它们时,它会说Subject.iloc[1, 0]-Subject.iloc[2, 0]TypeError: unsupported operand type(s) for -: 'datetime.time' and 'datetime.time'但后来我想也许我应该使用时间增量  pd.to_timedelta(Subject.iloc[2, 0].astype(str))上面写着 AttributeError: 'datetime.time' 对象没有属性 'astype'谁能帮我这个?我做错了什么?甚至这个pd.to_timedelta(Subject.iloc[2, 0]) won't work
查看完整描述

2 回答

?
牧羊人nacy

TA贡献1862条经验 获得超7个赞

你可以尝试这样做


d1 = datetime.datetime.combine(datetime.date.today(), Subject.iloc[2, 0])

d2 = datetime.datetime.combine(datetime.date.today(), Subject.iloc[1, 0])

diff = d1 - d2

要使用 Pandas' to_timedelta,请执行以下操作


pd.to_timedelta(str(Subject.iloc[2, 0]))


查看完整回答
反对 回复 2022-11-01
?
明月笑刀无情

TA贡献1828条经验 获得超4个赞

实际上,我最近不得不这样做。您可以将日期时间(或在我的情况下的时间结构对象)转换为“自纪元以来的秒数”,然后进行比较。

在 Python 中,如何将 `datetime` 对象转换为秒?

对我来说,情况更复杂:

durSec = time.mktime(time.strptime(data[7], "%Y-%m-%d %H:%M:%S")) - time.mktime(time.strptime(data[6], "%Y-%m-%d %H:%M:%S"))



查看完整回答
反对 回复 2022-11-01
  • 2 回答
  • 0 关注
  • 93 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号