2017-08-14 163 views
0

我试图计算创建和更新文件之前的时间差,以分钟计算丢失数据的数量。但我无法正确减去它们。我的代码如下。从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在这种情况下。我是编码新手。有人可以帮助我,在这方面如何获得单一的价值。

回答

0

首先,创建一个列表来保存minutes_values,然后使用内建的max()来获得最大值。

def main(): 
    fmt = '%Y-%m-%d %H:%M:%S' 
    with open('/home/kamil/Desktop/sensor1/temp.dat', 'rb') as f: 
     read = f.readlines()[1:] 
     minutes_values = [] 
     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.append(differ_time.total_seconds()/60) 
      missed = int(minutes_values/step_size) 
      expected = ......... 
      missing_data(expected, missed) 

    print 'minutes_values:::::::::::::::::::', max(minutes_values) 
+0

它说浮动对象是不可迭代的 –

+0

对不起,我很难测试何时不提供示例数据,否则我会在发布前测试。请在回路中的某处打印一份打印minutes_values语句来完整回溯,以帮助进行调试。 – Evan

+0

我犯了一个错误。我试过这样.............. minutes_values = differ_time.total_seconds()/ 60然后minutes_values.append(minutes_values)........它给我这个错误int不可迭代。 。所以我说得对。非常感谢您的帮助。 –

0

我也是初学者,但在我看来for循环是不必要的。看起来你只需要循环返回的第一个值(40.755),并且每个连续的值减少5,与步长= 5有关?如果你改变step_size,那么连续的时间改变那个数量?

如果for循环对于其他东西是必需的,则分开代码的两部分:一个计算时间差,一个计算for循环正在做的事情。

+0

如果我删除for循环,那么我怎么能得到第一行的第一个时间戳? –

+0

好吧,它看起来像'read',这些项目是以某种方式索引的,因为你可以遍历它们。难道你不知道指定'line.strip()。split()'命令是在line [0]上完成的,还是类似的东西? –