我正在解析一个日志文件,并将不同的值保存在不同的变量中。当我在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
,这是正确的。
答案 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'))