Python __eq__

Summary: in this tutorial, you’ll learn how to use the Python __eq__ method to compare two objects by their values.

Introduction to the Python __eq__ method

Suppose that you have the following Person class with three instance attributes: first_namelast_name, and age:

class Person: def __init__(self, first_name, last_name, age): self.first_name = first_name self.last_name = last_name self.age = ageCode language: Python (python)

And you create two instances of the Person class:

john = Person('John', 'Doe', 25) jane = Person('Jane', 'Doe', 25)Code language: Python (python)

In this example, the john and jane objects are not the same object. And you can check it using the is operator:

print(john is jane) # FalseCode language: Python (python)

Also, when you compare john with jane using the equal operator (==), you’ll get the result of False:

print(john == jane) # FalseCode language: Python (python)

Since john and jane have the same age, you want them to be equal. In other words, you want the following expression to return True:

john == jane

To do it, you can implement the __eq__ dunder method in the Person class.

Python automatically calls the __eq__ method of a class when you use the == operator to compare the instances of the class. By default, Python uses the is operator if you don’t provide a specific implementation for the __eq__ method.

The following shows how to implement the __eq__ method in the Person class that returns True if two person objects have the same age:

class Person: def __init__(self, first_name, last_name, age): self.first_name = first_name self.last_name = last_name self.age = age def __eq__(self, other): return self.age == other.ageCode language: Python (python)

Now, if you compare two instances of the Person class with the same age, it returns True:

john = Person('John', 'Doe', 25) jane = Person('Jane', 'Doe', 25) print(john == jane) # TrueCode language: Python (python)

And if two instances of the Person class don’t have the same age, the == operator returns False:

john = Person('John', 'Doe', 25) mary = Person('Mary', 'Doe', 27) print(john == mary) # FalseCode language: Python (python)

The following compares a Person object with an integer:

john = Person('John', 'Doe', 25) print(john == 20)Code language: PHP (php)

It returns an error:

AttributeError: 'int' object has no attribute 'age'Code language: JavaScript (javascript)

To fix this, you can modify the __eq__ method to check if the object is an instance of the Person class before accessing the age attribute.

If the other object isn’t an instance of the Person class, the __eq__ method returns False, like this:

class Person: def __init__(self, first_name, last_name, age): self.first_name = first_name self.last_name = last_name self.age = age def __eq__(self, other): if isinstance(other, Person): return self.age == other.age return FalseCode language: Python (python)

And you can now compare an instance of the Person class with an integer or any object of a different type:

john = Person('John', 'Doe', 25) print(john == 20) # FalseCode language: Python (python)

Putting it all together.

class Person: def __init__(self, first_name, last_name, age): self.first_name = first_name self.last_name = last_name self.age = age def __eq__(self, other): if isinstance(other, Person): return self.age == other.age return False john = Person('John', 'Doe', 25) jane = Person('Jane', 'Doe', 25) mary = Person('Mary', 'Doe', 27) print(john == jane) # True print(john == mary) # False john = Person('John', 'Doe', 25) print(john == 20) # False

Comments

Leave a Reply

Your email address will not be published. Required fields are marked *