Programação orientada a objetos em Python
Alex Yarosh
Content Quality Analyst @ DataCamp
class Customer: def __init__(self, name, balance): self.name, self.balance = name, balance customer1 = Customer("Maryam Azar", 3000) customer2 = Customer("Maryam Azar", 3000)customer1 == customer2
False
class Customer:
def __init__(self, name, balance, id):
self.name, self.balance = name, balance
self.id = id
customer1 = Customer("Maryam Azar", 3000, 123)
customer2 = Customer("Maryam Azar", 3000, 123)
customer1 == customer2
False
customer1 = Customer("Maryam Azar", 3000, 123)
customer2 = Customer("Maryam Azar", 3000, 123)
print(customer1)
<__main__.Customer at 0x1f8598e2e48>
print(customer2)
<__main__.Customer at 0x1f8598e2240>
import numpy as np
# Dois arrays diferentes com os mesmos dados
array1 = np.array([1,2,3])
array2 = np.array([1,2,3])
array1 == array2
True
class Customer: def __init__(self, id, name): self.id, self.name = id, name# Chamado quando == é usado def __eq__(self, other):# Impressão de diagnóstico print("__eq__() é chamado") # Retorna True se todos os atributos coincidirem return (self.id == other.id) and \ (self.name == other.name)
__eq__() é chamado quando 2 objetos de uma classe são comparados usando ==self e other - objetos a comparar# Dois objetos iguais
customer1 = Customer(123, "Maryam Azar")
customer2 = Customer(123, "Maryam Azar")
customer1 == customer2
__eq__() é chamado
True
# Dois objetos diferentes - ids diferentes
customer1 = Customer(123, "Maryam Azar")
customer2 = Customer(456, "Maryam Azar")
customer1 == customer2
__eq__() é chamado
False
| Operador | Método |
|---|---|
== |
__eq__() |
!= |
__ne__() |
>= |
__ge__() |
<= |
__le__() |
> |
__gt__() |
< |
__lt__() |
__hash__() para usar objetos como chaves de dicionário e em conjuntosProgramação orientada a objetos em Python