Почему я получаю IndexError: список индекса вне диапазона при разборе словаря? - PullRequest
0 голосов
/ 09 апреля 2020

Я пытаюсь выбрать таблицу из двух разных словарей, но после приведенного ниже значения l oop я получаю сообщение об ошибке "IndexError: список индексов вне диапазона".

Мой словарь;

>>> file_dict
{'NODES': ['BSHTAS1', 'GB-vMTAS', 'GBHTAS1', 'GBMTAS1', 'GBZLRF', 'MBHTAS01', 'MNDHTAS', 'SGT-vMTAS', 'SOGZLRF'],
 'KPIS': [['VoLTE MO Voice Connection Rate(%)', 'OK', 'OK', 'NOK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK'],
          ['VoLTE MO Voice Answer Rate(%)', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK'],
          ['VoLTE MO Voice Call Drop Times(times)', 'NOK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK'],
          ['VoLTE MO Video Connection Rate(%)', 'OK', 'OK', 'OK', 'OK', 'OK', 'NOK', 'NOK', 'OK', 'OK'],
          ['VoLTE MO Video Answer Rate(%)', 'OK', 'OK', 'NOK', 'OK', 'OK', 'NOK', 'NOK', 'OK', 'OK'],
          ['VoLTE MO Video Call Drop Times(times)', 'NOK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK'],
          ['VoLTE MT Voice Connection Rate(%)', 'NOK', 'OK', 'NOK', 'OK', 'OK', 'NOK', 'NOK', 'OK', 'OK'],
          ['VoLTE MT Voice Answer Rate(%)', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'NOK', 'OK', 'OK'],
          ['VoLTE MT Voice Call Drop Times(times)', 'OK', 'OK', 'OK', 'OK', 'OK', 'NOK', 'OK', 'OK', 'OK'],
          ['VoLTE MT Video Connection Rate(%)', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK'],
          ['VoLTE MT Video Answer Rate(%)', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK'],
          ['VoLTE MT Video Call Drop Times(times)', 'OK', 'OK', 'OK', 'OK', 'OK', 'NOK', 'OK', 'OK', 'OK'],
          ['VoLTE MO Request Times(times)', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK'],
          ['VoLTE MT Request Times(times)', 'OK', 'NOK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK', 'OK']
         ]}

И я хотел бы сделать заголовки клавишами ниже;

>>> file_dict["KPIS"][0][0]
'VoLTE MO Voice Connection Rate(%)'

Вот мой l oop. Не могли бы вы сказать мне, где моя ошибка? Большое спасибо ..

rows = []
headers = ["Kpis"]
for filename in file_list:
    file_content = open('{}'.format(filename), 'r').read()
    file_string = json.loads(file_content)
    # convert string to dictionary
    file_dict = eval(file_string)
    if "KPIS" in file_dict:
        ind = 0
        for eachkpi in file_dict["KPIS"]:
            t = [eachkpi]
            for eachnode in file_dict["KPIS"]:
                if eachnode[0][0] not in headers:
                    headers.append(eachnode[0][0])
                t.append(eachnode[ind + 1])
            rows.append(t)
            ind = ind + 1

Сообщение об ошибке;

Traceback (most recent call last):
  File "<stdin>", line 13, in <module>
IndexError: list index out of range
>>> 

1 Ответ

0 голосов
/ 09 апреля 2020

Быстрая заметка благодаря комментариям; Я не получаю ошибку, когда я делаю это транспонированным способом;

rows = []
headers = ["Nodes"]
for filename in file_list:
    file_content = open('{}'.format(filename), 'r').read()
    file_string = json.loads(file_content)
    # convert string to dictionary
    file_dict = eval(file_string)
    if "NODES" in file_dict:
        ind = 0
        for enode in file_dict["NODES"]:
            t = [enode]
            for ekpi in file_dict["KPIS"]:
                if ekpi[0] not in headers:
                    headers.append(ekpi[0])
                t.append(ekpi[ind + 1])
            rows.append(t)
            ind = ind + 1
...