Python字典因某些原因引发KeyError

时间:2013-06-20 19:05:20

标签: python dictionary

在某些代码中,我从列表中传递字典(TankDict)字符串。无论我输入什么字母,这都会引发KeyError。当我将字典复制并粘贴到程序的上下文中并从列表中传入相同的字母时,它们就会正确显示出来。我也运行了type(TankDict),它又回来了'dict'。 这是字典:     TankDict = {'E':0, 'F':1, 'G':2, 'H':3, 'I':4, 'J':5, 'K':6, 'L':7, 'M':8, 'N':9, 'O':10, 'P':11, 'Q':12, 'R':13, 'S':14, 'T':15, 'U':16, 'V':17, 'W':18, 'X':19}

错误:     enter code herechannelData[1] = tank_address_dict[channelData[1]] KeyError: 'L' (tank_address_dict是传递TankDict的函数参数)

channelData:['447', 'L', '15', 'C']

的内容

有谁可以告诉我(可能很简单)这种情况发生的原因?

编辑:代码!

这是错误的函数:

def getTankID(channel,tank_address_dict,PTM_dict,channel_ref):
rawChannelData = 'NA' 
for line in channel_ref:
    if str(channel) in line: rawChannelData = line
if(rawChannelData == 'NA'): return -1;
channelData = rawChannelData.split(' ')
channelData.extend(['',''])
channelData[1] = channelData[1][:-1]
channelData[3] = channelData[1][-1]
channelData[1] = channelData[1][:-1]
channelData[2] = channelData[1][1:]
channelData[1] = channelData[1][:1]
print channelData #debug
print 'L' in tank_address_dict
print 'E' in tank_address_dict
print 'O' in tank_address_dict
print 'U' in tank_address_dict
print type(tank_address_dict)
channelData[1] = tank_address_dict[channelData[1]]
channelData[3] = PTM_dict[channelData[3]]
return(channelData[1:])

这是调用它的函数:

def runFile(model, datafile, time_scale, max_PEs, tank_address_dict, PMT_dict, channel_ref):
#add initSerial for ser0-4
while(True):   
    raw_data = datafile.readline() #intake data
    if(raw_data == ''): break #End while loop if the file is done
    data = raw_data.split(' ')  #break up the parts of each line
    del data[::2]   #delete the human formatting
    data[2] = data[2][:-1] #rm newline (NOTE: file must contain blank line at end!)
    TankID = getTankID(data[0], tank_address_dict, PMT_dict,channel_ref)
    if(TankID == -1):
        print '!---Invalid channel number passed by datafile---!'; break #check for valid TankID
    model[TankID[0]][TankID[1]][TankID[2]] = scale(data[2],(0,max_PEs),(0,4096))
    createPackets(model)
    #updateModel(ser0,ser1,ser2,ser3,ser4,packet)
    data[2] = data[2]*time_scale #scale time
    time.sleep(data[2]) #wait until the next event
    print data #debug 
if(TankID != -1): print '---File',datafile,'finished---' #report errors in file run
else: print '!---File',datafile,'finished with error---!' 

这是调用它的代码:

import hawc_func
import debug_options
#begin defs
model = hawc_func.createDataStruct() #create the data structure
TankDict = hawc_func.createTankDict() #tank grid coordinate conversion table
PTMDict = hawc_func.createPMTDict() #PMT conversion table
log1 = open('Logs/log1.txt','w') #open a logfile
data = open('Data/event.txt','r') #open data
channel_ref = open('aux_files/channel_map.dat','r')
time_scale = 1 #0-1 number to scale nano seconds? to seconds
#end defs
hawc_func.runFile(model,data,4000,TankDict,PTMDict,time_scale,channel_ref)

#hawc_func.runFile(model,data,TankDict,PTMDict)
#close files
log1.close()
data.close()
#end close files
print '-----Done-----' #confirm tasks finished

tank_address_dict是通过这个函数创建的,由第3个代码块运行,然后通过另外两个代码传递:

def createTankDict():
    TankDict = {'E':0, 'F':1, 'G':2, 'H':3, 'I':4, 'J':5,
               'K':6, 'L': 7, 'M':8, 'N':9,
               'O':10, 'P':11, 'Q':12, 'R':13, 'S':14, 'T':15,
               'U':16, 'V': 17, 'W':18, 'X':19}
    return TankDict

1 个答案:

答案 0 :(得分:0)

您没有正确传递您的论据。

def runFile(model, datafile, time_scale, max_PEs, tank_address_dict, PMT_dict, channel_ref):

hawc_func.runFile(model,data,4000,TankDict,PTMDict,time_scale,channel_ref)

在这里,您有max_PEs = TankDict

这可能不是你唯一的问题。首先修复此问题,如果您仍然遇到问题,请使用固定代码更新您的帖子,然后告诉我们您的新错误是什么。