1

一部のコードでは、辞書 (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 番目のブロックによって実行され、他の 2 つのブロックに渡されます。

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
4

1 に答える 1

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

それはあなただけの問題ではないかもしれません。最初にそれを修正し、それでも問題が解決しない場合は、修正したコードで投稿を更新してから、新しいエラーの内容をお知らせください。

于 2013-06-20T19:27:56.913 に答える