为什么在datetime.time毫秒字段中添加了三个额外的零?

时间:2019-06-27 10:16:15

标签: python datetime milliseconds

我正在解析一个日志文件,并将不同的值保存在不同的变量中。当我在datetime.time(hour,minute,second,millisecond)中插入毫秒数时,它在毫秒数值前添加了三个额外的零,为什么?

lst = ['13', '33', '30.913']
hour = int(time[0], 10)
minute = int(time[1], 10)
second = int((time[2].split('.'))[0], 10)
millisecond = int((time[2].split('.'))[1], 10)
print(millisecond)
time = datetime.time(hour, minute, second, millisecond)
print(time)

我希望13:33:30:913中有print(time),但实际输出是13:33:30:000913

但是print(millisecond)的输出是913,这是正确的。

1 个答案:

答案 0 :(得分:1)

datetime.time的第四个参数实际上是微秒而不是毫秒:

  

datetime.time(小时= 0,分钟= 0,秒= 0,微秒= 0 ,tzinfo =无,*,倍数= 0)

为了使代码正常工作,您应该将毫秒乘以1000,然后可以使用isoformat方法进行打印:

time = datetime.time(hour, minute, second, millisecond * 1000)
print(time.isoformat('milliseconds'))