Я работаю над разбором диктовок, которые выглядят так:
data = {0: {},
1: {'1': 'M_AVL_002'},
2: {'2': 'CloudServiceAvailability'},
3: {'3': 'P_001'},
4: {'4': '2.592 x10^6'},
5: {'4': 'second'},
6: {'3': 'E_001'},
7: {'4': ' 100 x (P_001- M_TQD_001)/P_001'},
8: {'4': 'ISO80000'},
9: {'4': 'percentage'},
10: {'1': 'M_TQD_001'},
11: {'2': 'TotalQualifiedDowntime'},
12: {'3': 'E_001'},
13: {'4': '?(M_QDT_001)'},
14: {'4': 'ISO80000'},
15: {'4': 'second'}}
Я хочу получить доступ к таким значениям, как это:
for metric in XML.findall("{http://standards.iso.org/iso-iec/19086/-2/ed-1/en}Metric"):
for row,value in data.items() :
if (row==0):
pass
else :
for col,v in value.items():
if (col=="1"):
metric.set('id',str(data[row][col]))
if (col=="2"):
metric.set('description',str(data[row][col]))
if (col=="3"):
if (str(data[row][col]).startswith("E")):
metric.find('{http://standards.iso.org/iso-iec/19086/-2/ed-1/en}Expression').set("id",str(data[row][col]))
metric.find('{http://standards.iso.org/iso-iec/19086/-2/ed-1/en}Expression').set("expressionStatement",str(data[str(int(row)+1)][str(int(col)+1)]))
metric.find('{http://standards.iso.org/iso-iec/19086/-2/ed-1/en}Expression').set("expressionLanguage",str(data[str(int(row)+2)][str(int(col)+1)]))
metric.find('{http://standards.iso.org/iso-iec/19086/-2/ed-1/en}Expression').set("unit",str(data[str(int(row)+3)][str(int(col)+1)]))
elif (str(data[row][col]).startswith("P")):
for param in metric.findall('{http://standards.iso.org/iso-iec/19086/-2/ed-1/en}Parameter'):
if(str(data[row][col])==param.get('id')):
a=str(data[row][col])
print(str(int(row)+1),str(int(col)+1))
b=str(data[str(int(row)+1)][str(int(col)+1)])
c=str(data[str(int(row)+2)][str(int(col)+1)])
param.set("id",a)
param.set("parameterStatement",b)
param.set("unit",c)
else:
pass
elif (str(data[row][col]).startswith("R")):
for rule in metric.findall('{http://standards.iso.org/iso-iec/19086/-2/ed-1/en}Rule'):
if(str(data[row][col])==rule.get('id')):
a=str(data[row][col])
b=str(data[str(int(row)+1)][str(int(col)+1)])
rule.set("id",a)
rule.set("ruleStatement",b)
else :
pass
Однако у меня есть KeyError
в строке, где назначено b
.Я попытался напечатать row
и col
и проверил, являются ли строки + 1 и col + 1 ключами, и они есть.
В случае, если программа аварийно завершает работу row = 6 и col = 3, поэтому в этом расположении есть значение, но это также верно для row = 7 и col = 4, и у меня есть: KeyError :'7'