Что такое методы Дандера?

Это методы, связанные с классом в Python.

Цель их состоит в том, чтобы предложить полезную функциональность классам.

Чтобы просмотреть все методы Dunder, связанные с объектом ( str в нашем примере), мы можем использовать встроенную функцию dir следующим образом.

print(dir(str))

Это выводит на:

['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'removeprefix', 'removesuffix', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']

Что такое «Дандер»?

Эти методы имеют двойное подчеркивание в качестве префикса и суффикса к их имени, и поэтому они называются методами «Dunder» (двойное подчеркивание).

Например, метод __init__.

Когда ты им звонишь?

Вы не вызываете эти методы напрямую, но эти методы вызываются внутри, когда вы получаете доступ к соответствующим функциям, предоставляемым этими методами.

Например, метод __init__ вызывается внутри при инициализации экземпляра класса.

Давай начнем!

Это общие методы Dunder, о которых вам следует знать, если вы занимаетесь объектно-ориентированным программированием на Python:

__в этом__

Этот метод вызывается при инициализации экземпляра/объекта класса.

Он принимает ключевое слово self в качестве обязательного параметра.

self представляет экземпляр определенного класса.

class Person:
def __init__(self,name,address):
self.name = name
self.address = address
person_1 = Person("John","5, High Street")
view raw __init__.py hosted with ❤ by GitHub

__новый__

Это первый метод, который вызывается при инициализации экземпляра/объекта класса.

Он принимает ключевое слово cls в качестве обязательного параметра.

cls является представлением определенного класса.

__new__ возвращает экземпляр/объект класса, который позже инициализируется __init__ .

__eq__

Этот метод используется для определения работы оператора ==.

Посмотрим, как это работает!

Мы создаем два экземпляра ранее определенного класса Person, как person_1 и person_2.

Используя метод __eq__, мы меняем поведение оператора ==, чтобы он возвращал строку на основе результата операции.

class Person:
def __init__(self, name, address):
self.name = name
self.address = address
def __eq__(self, other):
if self.name == other.name and self.address == other.address:
return 'These are the same people'
else:
return 'These are different people'
person_1 = Person("John","5 Rome Street")
person_2 = Person("John","6 Harrow")
print(person_1 == person_2)
# Output: 'These are different people'
view raw __eq__.py hosted with ❤ by GitHub

Сходным образом,

__ne__(self, other)можно использовать для !=

__lt__(self, other)можно использовать для <

__gt__(self, other)можно использовать для >

__le__(self, other)можно использовать для <=

__ge__(self, other)можно использовать для >=

__добавлять__

Этот метод используется для определения работы оператора +.

Посмотрим, как это работает!

Мы создаем два экземпляра класса Account, которые содержат один параметр balance.

Используя метод __add__, мы меняем поведение оператора +, чтобы он возвращал сумму остатков на счетах в строковом формате.

class Account:
def __init__(self, balance):
self.balance = balance
def __add__(self, other):
return "The total balance is {} GBP.".format(self.balance + other.balance)
account_1 = Account(500)
account_2 = Account(250)
print(account_1 + account_2)
# Output: The total balance is 750 GBP.
view raw __add__.py hosted with ❤ by GitHub

Сходным образом,

__sub__(self, other)может использоваться для оператора вычитания (-)

__mul__(self, other)может использоваться для оператора умножения (*)

__div__(self, other)может использоваться для оператора деления (/)

__mod__(self, other)можно использовать для оператора по модулю (%)

__pow__(self, other)может использоваться для оператора возведения в степень (**)

__repr__

Этот метод возвращает строковое представление экземпляра/объекта класса.

Посмотрим, как это работает!

Мы создадим класс Wallet и определим его метод __repr__, как показано ниже:

class Wallet:
def __init__(self, balance):
self.balance = balance
def __repr__(self):
return "The balance of this wallet is {} GBP.".format(self.balance)
wallet = Wallet(500)
print(wallet)
# Output : The balance of this wallet is 500 GBP.
view raw __repr__.py hosted with ❤ by GitHub

__getattr__

С помощью этого метода можно управлять поведением, когда пользователь пытается получить доступ к несуществующему атрибуту.

class Student:
def __init__(self,name,grade):
self.name = name
self.grade = grade
def __getattr__(self, attr):
return "{} attribute does not exist!".format(attr.upper())
student = Student("Ashish", "A")
print(student.name)
# Output : Ashish
print(student.address)
# Output : ADDRESS attribute does not exist!
view raw __len__.py hosted with ❤ by GitHub

Чтобы узнать больше о методах Dunder, обратитесь к ресурсам, указанным ниже.





Большое спасибо за чтение этой статьи!