В случае, если это помогает ... если вам действительно нужно по какой-то причине преобразовать не подлежащие обработке вещи в хешируемые эквиваленты, вы можете сделать что-то вроде этого:
from collections import Hashable, MutableSet, MutableSequence, MutableMapping
def make_hashdict(value):
"""
Inspired by /1297660/python-hashable-dicts
- with the added bonus that it inherits from the dict type of value
so OrderedDict's maintain their order and other subclasses of dict() maintain their attributes
"""
map_type = type(value)
class HashableDict(map_type):
def __init__(self, *args, **kwargs):
super(HashableDict, self).__init__(*args, **kwargs)
def __hash__(self):
return hash(tuple(sorted(self.items())))
hashDict = HashableDict(value)
return hashDict
def make_hashable(value):
if not isinstance(value, Hashable):
if isinstance(value, MutableSet):
value = frozenset(value)
elif isinstance(value, MutableSequence):
value = tuple(value)
elif isinstance(value, MutableMapping):
value = make_hashdict(value)
return value
my_set = set()
my_set.add(make_hashable(['a', 'list']))
my_set.add(make_hashable({'a': 1, 'dict': 2}))
my_set.add(make_hashable({'a', 'new', 'set'}))
print my_set
Моя реализация HashableDict - самый простой и наименее строгий примерот здесь .Если вам нужен более продвинутый HashableDict, который поддерживает травление и другие вещи, проверьте множество других реализаций.В моей версии выше я хотел сохранить исходный класс dict, сохраняя порядок OrderedDicts.Я также использую AttrDict из здесь для доступа, подобного атрибуту.
Мой пример выше ни в коем случае не является авторитетным, просто мое решение аналогичной проблемы, где мне нужно было хранить некоторые вещи вустановить и нужно сначала их "хешировать".