前言
我知道dicts/ sets 应该只由于它们的实现而用可散列对象创建/更新,所以当这种代码失败时
>>> {{}} # empty dict of empty dict
Traceback (most recent call last):
File "<input>", line 1, in <module>
TypeError: unhashable type: 'dict'
没关系,我已经看到大量此类消息。
但是如果我想检查一些不可散列的对象是否在set/dict
>>> {} in {} # empty dict not in empty dict
我也收到错误
Traceback (most recent call last):
File "<input>", line 1, in <module>
TypeError: unhashable type: 'dict'
问题
这种行为背后的原因是什么?我知道查找和更新可能在逻辑上是相连的(就像在dict.setdefaultmethod 中一样),但它不应该在修改步骤而不是查找中失败吗?也许我有一些我以某种方式处理的可散列的“特殊”值,但其他(可能无法散列) - 在另一个中:
SPECIAL_CASES = frozenset(range(10)) | frozenset(range(100, 200))
...
def process_json(obj):
if obj in SPECIAL_CASES:
... # handle special cases
else:
... # do something else
所以对于给定的查找行为,我被迫使用其中一个选项
LBYL方式:检查是否obj是可散列的,然后才检查它是否是其中之一SPECIAL_CASES(这不是很好,因为它基于SPECIAL_CASES结构和查找机制限制,但可以封装在单独的谓词中),
EAFP方式:使用某种实用程序进行“安全查找”,例如
def safe_contains(dict_or_set, obj):
try:
return obj in dict_or_set
except TypeError:
return False
使用list/ tuplefor SPECIAL_CASES(不在O(1)查找中)。
还是我错过了一些微不足道的东西?
慕容708150
jeck猫
相关分类