python中的对象等价性收藏。国家

2024-03-28 20:54:44 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个例子集合。计数器类,我还有一些对象,比如:

p1 = Person(name='John')
p2 = Person(name='John')
p3 = Person(name='Jane')

我想在一个Counter实例中保存这个person对象的计数,考虑到具有相同名称的person对象必须增加相同的person计数,因此如果我有一个包含所有person对象的列表:

^{pr2}$

我用它填充我的计数器:

c = Counter(people)

我想得到以下信息:

c[p1] #prints 2
c[p2] #prints 2
c[p3] #prints 1

我的第一次尝试是为person对象实现一个新的__eq__方法

def __eq__(self, other):
  return self.name == other.name

我认为这是可行的,因为计数器对象似乎增加了计数 对于基于键对象相等的键,例如:

c = Counter(['A', 'A', 'B'])
c['A'] #prints 2
c['B'] #prints 1

另一个尝试可以从计数器继承并重写 计数器用于测量物体之间的相等,我不确定,但我认为 Counter为此使用__contains__方法。在

我的问题是,是否有任何方法可以在不使用继承的情况下获得这种行为,如果没有,最好的方法是什么?。在


Tags: 对象方法nameselfcounter计数器johnprints
2条回答

如果您的对象像您的示例中那样简单,请使用collections.namedtuple

from collections import Counter, namedtuple
Person = namedtuple('Person','name')

n1 = Person(name='John')
n2 = Person(name='John')
n3 = Person(name='Jane')
Counter((n1,n2,n3))
# Counter({Person(name='John'): 2, Person(name='Jane'): 1})

实施{cd1>还必须:

class Person(object):
    def __init__(self, name=None, address=None):
        self.name = name
        self.address = address

    def __eq__(self, other):
        return self.name == other.name and self.address == other.address

    def __hash__(self):
        return hash((self.name, self.address))

现在您的代码可以工作了:

^{pr2}$

相关问题 更多 >