从文件中提取数据和信号

时间:2015-07-14 05:51:45

标签: python dictionary key next

在我开始之前,我只是在这里和Python中的初学者,我正在研究从文件中提取数据,然后从产生数据信号所需的数据。我不知道如何解释它,但我会尽力解释这个问题。我得到了一个文本文件,如:

12 0011
15 001a
20 111e
32 8877
50 00f3 
56 1000

我能够读取文件并将它们放入字典中:

def dictionary(filename):
 d = {}
 f = open(filename,'r')
 for lines in f:
  line = lines.split(' ',1)
  line[1] = line[1].replace('\n','')
  d[line[0]] = line[1]
 f.close()
 for k in sorted(d.keys()):
  print 'Keys:', k, '-> Values:', d[k]
 return d

第二部分,它与文本文件有关,第一列表示时间,第二列表示数据。这意味着在时间= 15s时,数据是001a直到时间= 20s,其中数据变为111e。数据继续相同(111e)直到时间= 32s,其中数据再次变为8877。同样的过程继续下去。我被要求在时间内以1s的间隔提取从时间= 15s到时间= 60s产生的输出。问题是我不知道做这部分的确切方法。我不知道怎么去下一把钥匙。我已尝试使用enumerate(d),但它会弹出AttributeError。我也试过d.iteritems().next(),但它进入无限循环。这是我的代码:

def output(d):
 a = 0
 keys = sorted(d.keys())
 while a <= 45:
  time = a + 15
  for k in keys:
   if time == k:
    sig = d[k]
   else:
    while time != k:
     k = d.iteritems().next()[0]
  print 'Time:', time, '-> Signal:' sig
  a += 1

任何人都可以帮助我吗?非常感谢。

编辑:为了更好地理解,预期输出如下:

Time: 15s -> Signal: 001a
Time: 16s -> Signal: 001a
Time: 17s -> Signal: 001a
Time: 18s -> Signal: 001a
Time: 19s -> Signal: 001a
Time: 20s -> Signal: 111e
Time: 21s -> Signal: 111e
Time: 22s -> Signal: 111e 
Time: 23s -> Signal: 111e 
... 
Time: 31s -> Signal: 111e 
Time: 32s -> Signal: 8877
Time: 33s -> Signal: 8877
...
Time: 49s -> Signal: 8877
Time: 50s -> Signal: 00f3
Time: 51s -> Signal: 00f3
...
Time: 55s -> Signal: 00f3
Time: 56s -> Signal: 1000
Time: 57s -> Signal: 1000

...代表仍在运行的时间。这是为了显示根据上面的文本文件的数据转换。输出最高可达60秒

1 个答案:

答案 0 :(得分:2)

假设您的文件为signals.txt

def read_signal(filename):
    with open(filename) as fh1:
        d = {}
        for line in fh1:
            (t, s) = line.split()
            d[int(t)] = s
        for i in range(15,61):
            if i in sorted(d):
                j = d[i]
            print ("Time: " + str(i) + "s -> Signal: " + j)
read_signal("signals.txt")