通过使用文本文件在python中的字典元组

时间:2017-10-16 08:30:28

标签: python dictionary tuples

我有一个代码,它返回一个字典 作为键的名称和作为元组的对应值 数字。名称后面的第一个数字控制着多少个数字 在相应的元组中(包含在元组中的数字被采用 从左到右)。例如,文本行"Ali 6 7 6 5 12 31 61 9"的名称和此行文本后面的第一个数字为6 成为字典条目,关键字“阿里”和 对应的值是由接下来的六个整数“Ali”组成的元组: (7,6,5,12,31,61)。

这是我从

获取代码的电影
  Bella 5 2 6 2 2 30 4 8 9 2
  Gill 2 9 7 54 67
  Jin 3 26 51 3 344 23 
  Elmo 4 3 8 6 8
  Ali 6 7 6 5 12 31 61 9

预期输出

Ali : (7, 6, 5, 12, 31, 61)
Bella : (2, 6, 2, 2, 30)
Elmo : (3, 8, 6, 8)
Gill : (9, 7)
Jin : (26, 51, 3)

所以我这样做了

   def get_names_num_tuple_dict(filename):      
   file_in = open(filename, 'r')
   contents = file_in.read()
   file_in.close()
   emty_dict = {}
   for line in contents:
      data = line.strip().split()
      key = data[0]
      length = int(data[1])
      data = tuple(data[2:length + 2])
      emty_dict[key] = data

   return emty_dict

但我有这个错误     length = int(data [1]) IndexError:列表索引超出范围

有人可以帮忙吗?这将非常有帮助。我第一次学习字典时有点弱。

2 个答案:

答案 0 :(得分:1)

使用以下代码:

def get_names_num_tuple_dict(filename):      
   emty_dict = {}
   with open(filename) as f:
      for line in f:
         data = line.strip().split()
         key = data[0]
         length = int(data[1])
         data = tuple(data[2:length + 2])
         emty_dict[key] = data

   return emty_dict


print(get_names_num_tuple_dict('my_filename'))

输出:

{'Bella': ('2', '6', '2', '2', '30'), 'Gill': ('9', '7'), 'Jin': ('26', '51', '3'), 'Elmo': ('3', '8', '6', '8'), 'Ali': ('7', '6', '5', '12', '31', '61')}

答案 1 :(得分:0)

以下是发生的事情:

contents = file_in.read()

将您的文件读入字符串。当你循环遍历这个字符串时,它将逐字逐句地给你IndexError: list index out of range

基本上尝试使用:

for line in file_in:
    data = line.strip().split()
        ...