我试图计算创建和更新文件之前的时间差,以分钟计算丢失数据的数量。但我无法正确减去它们。我的代码如下。从python的csv文件的当前日期时间减去日期时间
在文件中的数据是这样的:
DATE,temp1
2017-08-14 17:10:01,0.44
2017-08-14 17:15:01,0.62
2017-08-14 17:20:01,0.99
2017-08-14 17:25:01,0.85
2017-08-14 17:30:01,0.13
2017-08-14 17:35:01,0.24
2017-08-14 17:40:02,0.95
2017-08-14 17:45:01,0.65
而且代码:
#!/usr/bin/env python
# -*-coding:utf-8 -*
import os
import sys
import time
from time import mktime, strftime, localtime, sleep
from datetime import datetime, timedelta
def missing_data(expect, missed):
.
.
.
.
def main():
fmt = '%Y-%m-%d %H:%M:%S'
with open('/home/kamil/Desktop/sensor1/temp.dat', 'rb') as f:
read = f.readlines()[1:]
for line in read:
line = line.strip().split(',')
# print line
start_date = line[0] # type is str so i convert it to datetime
start_date = datetime.strptime(start_date, fmt) # type is datetime.datetime and here I need the first timestamp in the file only
current_time = datetime.now()
step_size = 5
differ_time = current_time - start_date
minutes_values = differ_time.total_seconds()/60
print 'minutes_values:::::::::::::::::::', minutes_values
missed = int(minutes_values/step_size)
expected = .........
missing_data(expected, missed)
if __name__ == '__main__':
main()
如果我打印minutes_values,它给我的结果是这样的:
40.755
35.7553
30.755
25.755
20.755
15.755
10.755
5.755
0.755
但我只是需要最后的值,例如40.755在这种情况下。我是编码新手。有人可以帮助我,在这方面如何获得单一的价值。
它说浮动对象是不可迭代的 –
对不起,我很难测试何时不提供示例数据,否则我会在发布前测试。请在回路中的某处打印一份打印minutes_values语句来完整回溯,以帮助进行调试。 – Evan
我犯了一个错误。我试过这样.............. minutes_values = differ_time.total_seconds()/ 60然后minutes_values.append(minutes_values)........它给我这个错误int不可迭代。 。所以我说得对。非常感谢您的帮助。 –