Итак, у меня есть этот индекс как dict.
index = {'Testfil2.txt': ['nisse', 'hue', 'abe', 'pind'], 'Testfil1.txt': ['hue', 'abe',
'tosse', 'svend']}
Мне нужно инвертировать индекс, чтобы это был словарь с дубликатами значений, объединенных в один ключ с двумя исходными ключами в качестве значений, например:
inverse = {'nisse' : ['Testfil2.txt'], 'hue' : ['Testfil2.txt', 'Testfil1.txt'],
'abe' : ['Testfil2.txt', 'Testfil1.txt'], 'pind' : ['Testfil2.txt'], 'tosse' :
['Testfil1.txt'], 'svend' : ['Testfil1.txt']
Да, я напечатал выше написанное вручную.
В моем учебнике есть такая функция для инвертирования словарей:
def invert_dict(d):
inverse = dict()
for key in d:
val = d[key]
if val not in inverse:
inverse[val] = [key]
else:
inverse[val].append(key)
return inverse
Он отлично работает для простых пар ключ: значение
НО, когда я пробую эту функцию с dict, в котором есть списки как значения, такие как мой index
, я получаю это сообщение об ошибке:
invert_dict(index)
Traceback (most recent call last):
File "<pyshell#153>", line 1, in <module>
invert_dict(index)
File "<pyshell#150>", line 5, in invert_dict
if val not in inverse:
TypeError: unhashable type: 'list'
Я искал решение в течение часа, книга не помогла, и я подозреваю, что могу каким-то образом использовать кортежи, но я не уверен, как это сделать. Любая помощь?