我见过多个线程,人们遇到同样的问题,但由于问题的独特性,似乎已逐个提供解决方案
这是我的代码:
loga = [(912, "Message A1") , (1000, "Message A2") , (988, "Message A3") , (1012, "Message A4") , (1002, "Message A5")]
logb = [(926, "Message B1") , (1008, "Message B2") , (996, "Message B3") , (1019, "Message B4") , (1100, "Message B5")]
logc = [(1056,"Message C1") , (1033, "Message C2") , (999, "Message C3") , (1054, "Message C4") , (1086, "Message C5")]
logs = [loga, logb, logc]
out = []
def find_lowest_i(lst):
for i in range(len(lst)):
log = lst[i]
if log:
t = log[0][0]
if i==0 or t < lowest_t:
lowest_i = i
lowest_t = t
return lowest_i
while True:
i = find_lowest_i(logs)
print "i=", i
tpl = logs[i].pop(0)
print tpl
out.append(tpl)
print out
我的确切错误:
“消息文件名称行位置追溯19 find_lowest_i 13
UnboundLocalError:在赋值“
答案 0 :(得分:1)
由于连续pop
,其中一个日志(包含此数据,第一个日志)最终将为空:
logs = [[],
[(1019, 'Message B4'), (1100, 'Message B5')],
[(1056, 'Message C1'), (1033, 'Message C2'), (999, 'Message C3'),
(1054, 'Message C4'), (1086, 'Message C5')]]
在这种情况下,if log
将因i = 0而失败,并且lowest_t
未初始化。
在下一次迭代中,i = 1,有log
但没有lowest_t
。例外!