如何为python类定义“in”

时间:2018-05-15 15:37:21

标签: python python-3.x class compare

如果我有一个包含字符串字段的python类的列表,有没有办法使用in将字符串与该类的对象列表进行比较?我很好奇是否有办法做这样的事情:

class Foo:
    def __init__(self, s):
        self.s = s

bar = Foo('test')
ls = [bar]

if 'test' in ls:
    print("Yay!")

通过修改__eq__方法,或者甚至可能有__in__方法,我不知道

2 个答案:

答案 0 :(得分:2)

您对修改__eq__的猜测是正确的。这绝对是一种方法。您只需要使用对象的相应属性检查__eq__参数的值。因此,您可以通过非常简单的方式实现以下内容:

In [1]: class Foo:
   ...:     def __init__(self, s):
   ...:         self.s = s
   ...:
   ...:     def __eq__(self, value):
   ...:         return self.s == value
   ...:     

In [2]: bar = Foo('test')
   ...: ls = [bar]
   ...: 

In [3]: 'test' in ls
Out[3]: True

请注意,此__eq__方法没有任何限制,例如类型检查或其他一些错误处理。如果您认为在您的情况下需要它们,您可以考虑使用try-excep和/或其他条件检查。

演示:

In [9]: foo = Foo('test')

In [10]: bar = Foo('test')

In [11]: ls = ['test']

In [12]: bar in ls
Out[12]: True

In [13]: ls = [bar]

In [14]: foo in ls
Out[14]: True

答案 1 :(得分:2)

您对定义自定义__eq__的直觉是正确的。您可以实现以下目标,这似乎是您的目标:

>>> class Foo:
...     def __init__(self, s):
...         self.s = s
...     def __eq__(self, other):
...         if isinstance(other, Foo):
...             return self.s == other.s
...         else:
...             return self.s == other
...
>>>
>>> bar = Foo('bar')
>>> l = [bar]
>>> bar in l
True
>>> 'bar' in l
True
>>> Foo('baz') in l
False
>>> 'baz' in l
False

我还想指出有__contains__方法,它允许您定义成员资格运算符的行为(in)。但是这是容器类型的方法,因此在这里为类Foo定义此方法不会执行任何操作,因为in应用于列表,而不是其单个项目。