Что такое методы Дандера?
Это методы, связанные с классом в 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") |
__новый__
Это первый метод, который вызывается при инициализации экземпляра/объекта класса.
Он принимает ключевое слово 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' | |
Сходным образом,
__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. |
Сходным образом,
__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. | |
__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! |
Чтобы узнать больше о методах Dunder, обратитесь к ресурсам, указанным ниже.
Большое спасибо за чтение этой статьи!