![](/img/trans.png)
[英]Python: how to make comparable hashable objects of the same type to be treated by set/dict as the single object?
[英]How to check if, in a given list of objects, each different type of object is comparable?
作为防御性编程的一种手段,我实现了一段相当简单的代码来检查传递给我的函数的给定列表的所有元素(不同类型)是否通过比较运算符相互比较(有一个或所有的丰富比较方法)。
我对此的看法是迭代列表并将可用类型与字典中每个对象的单个实例一起编目,然后遍历字典的键,将每个选定的对象相互比较以查看它们是否返回布尔值或引发TypeError
。
下面是我的想法的实现:
test = [1, 2, 'str', 4.5, {'r':'d'}]
type_dict = {}
for elem in test:
if not isinstance(elem, tuple(type_dict.keys())):
type_dict[type(elem)] = elem
cmp = True
for obj1 in type_dict.keys():
for obj2 in type_dict.keys():
try:
type_dict.get(obj1) > type_dict.get(obj2)
except TypeError:
cmp = False
break
if not cmp:
break
if cmp:
print('Objects in list are comparable.')
else:
print('Objects in list are not comparable.')
出于好奇,是否有更简洁的方法通过内置的python 或库来做到这一点?
您所要做的就是尝试对列表进行排序。
try:
sorted(list_of_elements)
print('Objects in list are comparable.')
except TypeError:
print('Objects in list are not comparable.')
我不确定我是否正确理解了你的问题,但我认为你可以做一些相当简单的事情,比如:
def check_type(test) :
for i in test :
if type(test[i])!=type(test[0]) :
return False
return True
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.