您正在尝试将 adict
用作另一个dict
或set
. 这不起作用,因为密钥必须是可散列的。作为一般规则,只有不可变对象(字符串、整数、浮点数、冻结集、不可变元组)是可散列的(尽管可能有例外)。所以这不起作用:
>>> dict_key = {"a": "b"}
>>> some_dict[dict_key] = True
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unhashable type: 'dict'
要将 dict 用作键,您需要将其转换为可能首先被散列的东西。如果您希望用作键的 dict 仅包含不可变的值,则可以像这样创建它的可散列表示:
>>> key = frozenset(dict_key.items())
现在您可以在 a或key
中用作键:dict
set
>>> some_dict[key] = True
>>> some_dict
{frozenset([('a', 'b')]): True}
当然,当您想使用 dict 查找某些内容时,您需要重复该练习:
>>> some_dict[dict_key] # Doesn't work
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unhashable type: 'dict'
>>> some_dict[frozenset(dict_key.items())] # Works
True
如果dict
您希望用作键的值本身就是字典和/或列表,则需要递归地“冻结”预期键。这是一个起点:
def freeze(d):
if isinstance(d, dict):
return frozenset((key, freeze(value)) for key, value in d.items())
elif isinstance(d, list):
return tuple(freeze(value) for value in d)
return d