我已经花了好几天时间在编写代码上,说实话,我的头发快掉光了...我已经到处搜索,包括stackoverflow,但似乎找不到符合我困境的任何东西。
我正在使用Mint 17.3上的Python 2.7.6。我需要至少以毫秒精度处理日期/时间。处理整秒的日期和时间相当简单,但是当你加入毫秒或微秒时,它就变成了完全不同的游戏。最终,我需要遍历日志文件,并基于某些条件,找到两行日期/时间之间的差异,至少要达到毫秒精度。在这个仓库输送机情况下涉及服务器、PLC和扫描仪,精度确实很重要。日志文件的日期/时间格式如下:
12-Apr-2016 23:59:59.720321
我认为最简单的方法是将字符串转换为时间戳,然后再添加微秒。但是我对在这种情况下使用strptime并不确定,因为我知道timetuple()会剥离任何小数部分,因此这是多余的。
经过多次尝试和数天的努力,我目前的代码如下:
def timestampthen(timestring):
tt = datetime.datetime.strptime(timestring, "%d-%b-%Y %H:%M:%S.%f").timetuple()
ut = float(calendar.timegm(tt))
dotpos = timestring.rfind(".")
frac = float(timestring[dotpos:])
utfloat = float(ut + frac)
return utfloat
在一个例子中,ut = 1460505599.0,frac = 0.720321,但是utfloat = 1460505599.72。
我知道可以使用format和%f,但我正在使用浮点数而不是字符串。 上面的代码运行良好,但是当浮点数精度为6个或更多个小数点时,为什么会返回2位小数呢?我需要更多。 请帮我指点一下方向,谢谢。
utfloat
是1460505599.720321
。你怎么能说你的utfloat
被舍入了呢?通过打印吗?utfloat > 1460419273.37
返回什么? - Francesco1460419273.0 0.373317 1460419273.37
- David Johnsutfloat > 1460419273.72
,你得到的是True
还是False
? - Francesco