我有一个代码,它返回一个字典
作为键的名称和作为元组的对应值
数字。名称后面的第一个数字控制着多少个数字
在相应的元组中(包含在元组中的数字被采用
从左到右)。例如,文本行"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:列表索引超出范围
有人可以帮忙吗?这将非常有帮助。我第一次学习字典时有点弱。
答案 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()
...