在Django中,我编写了一个基于类的自定义验证器并实现了__eq__
方法,因为它也已由Django本身已经实现的验证器完成。
在这里您可以看到它:
@deconstructible
class FileSizeValidator:
def __init__(self, mb):
self.mb = mb
def __call__(self, value):
limit = self.mb * 1024 * 1024
if value.size > limit:
raise ValidationError('File too big (max. ' + str(self.mb) + ' MiB).')
def __eq__(self, other):
return (
isinstance(other, FileSizeValidator) and
self.mb == other.mb
)
现在,我还为ImageField
编写了一个自定义类。我想将其用于upload_to=
模型中的ImageField
参数。在这里您可以看到我的示例:
@deconstructible
class RandomFileName:
def __init__(self, directory=''):
self.directory = directory
def __call__(self, instance, filename):
return self.directory + ("/" if self.directory else '') + get_random_string(7) + "." + filename.split('.')[-1]
def __eq__(self, other):
return (
isinstance(other, RandomFileName) and
self.directory == other.directory
)
总的来说,我对此感到满意,并且看起来效果很好。我只是不知道何时,我需要使用__eq__
方法,并想请您解释一下。
答案 0 :(得分:2)
这称为运算符重载,在您的示例中,它用于比较两个对象。实施__eq__()
方法后,您可以将任何其他对象与您的对象进行相等性比较。
我们现在可以从您的班级创建两个对象:
obj1 = FileSizeValidator(100)
obj2 = FileSizeValidator(200)
并可以将它们比较为obj1 == obj2
。
由于我们定义了自定义__eq__()
,因此将比较对象的class
和mb
属性的值以返回True
或False
值。如果任何条件失败,它将返回False
。
在python中,默认情况下,两个自定义对象的相等运算符将比较对象的id
值,并且除非将对象与其自身进行比较,否则永远不会返回True
。