Python: How do sets work

2020-05-31 15:49发布

I have a list of objects which I want to turn into a set. My objects contain a few fields that some of which are o.id and o.area. I want two objects to be equal if these two fields are the same. ie: o1==o2 if and only if o1.area==o2.area and o1.id==o2.id.

I tried over-writing __eq__ and __cmp__ but I get the error: TypeError: unhashable instance.

What should I over-write?

标签: python hash set
2条回答
干净又极端
2楼-- · 2020-05-31 16:42

"TypeError: unhashable instance." error is probably due to old-style class definition i.e.:

class A:
  pass

Use new style instead:

class A(object):
  pass

If you override __cmp__ function you should override __hash__ for using your object in sets. In the other case hash considers all object instances as unequal and __cmp__ function will never be called.

查看更多
趁早两清
3楼-- · 2020-05-31 16:46

Define the __hash__ method to return a meaningful hash based on the id and area fields. E.g.:

def __hash__(self):
    return hash(self.id) ^ hash(self.area)
查看更多
登录 后发表回答