在python中获取时间戳差异的方法

时间:2018-10-11 19:43:00

标签: python linux

我正在尝试测量引导加载程序的时间,其中我需要测量SPL,U-Boot和总时间(SPL + U-Boot)。我的minicom控制台日志条目如下所示

  

$ cat u-boot-2017-01 | grep -e 'U-Boot SPL 2017' -e 'U-Boot 2017.01' -e 'Starting kernel ...'
[2018-10-11 15:05:11.021] U-Boot SPL 2017.01-05786-ge0aa2fcb13 (Oct 10 2018 - 13:53:01)
[2018-10-11 15:05:11.294] U-Boot 2017.01-05786-ge0aa2fcb13 (Oct 10 2018 - 13:53:01 -0400)
[2018-10-11 15:05:12.706] Starting kernel ...

现在

  

SPL引导时间为:第1行和第2行的时间戳差异(SPL开始和   U-Boot启动)
  U-Boot的启动时间是:第2行和   第3行(U-Boot启动和启动内核)
  总时间是:时间戳   第1行和第3行的差异。

我看到python timedelta支持年,月,日,小时,分钟,秒,微秒,毫秒,但不确定如何将此时间戳转换为timedelta。我正在学习python,所以想在那里尝试。有人可以建议应该怎么做。我必须对多种产品和多种版本的引导程序进行这些测量,以便编写脚本会很不错。

1 个答案:

答案 0 :(得分:2)

使用datetime.strptime,这非常简单,只需要确保使用正确的格式即可。

请参阅可用的指令here

from datetime import datetime

start_time = '2018-10-11 15:05:11.021'
end_time = '2018-10-11 15:05:11.294'

FORMAT = '%Y-%m-%d %H:%M:%S.%f'

print(datetime.strptime(end_time, FORMAT) - datetime.strptime(start_time, FORMAT))
# 0:00:00.273000