👍3🔥1🤯1
  Атрибут 
Когда в коде пишется
category в классе C1 создаётся внутри метода (__init__), а значит, он становится атрибутом экземпляра, а не атрибутом класса. Такой атрибут доступен только после создания объекта через C3(), и обращаться к нему нужно через сам объект (obj.category), а не через класс (C3.category).Когда в коде пишется
print(C3.category), Python пытается найти атрибут класса с именем category у C3 или его родителей. Но такого атрибута нет — category создаётся только при вызове конструктора (__init__). Поэтому попытка обращения к C3.category приводит к ошибке AttributeError.👍3🤯2😁1🤔1🙏1
  🔍 Что происходит, когда метод класса в Python выполняет присваивание значения с использованием self, например self.attr = 10?
  Anonymous Quiz
    10%
    Атрибут attr создается как переменная внутри метода и удаляется после его выполнения
      
    16%
    Атрибут attr создается в классе, от которого был вызван метод
      
    70%
    Атрибут attr создается или обновляется в текущем экземпляре, на котором вызван метод
      
    4%
    Атрибут attr создается в самом верхнем родительском классе
      
    👍4🤬1
  Когда в методе используется 
Таким образом, присваивание через
self.attr = ..., Python создает (или обновляет) атрибут у конкретного экземпляра, на котором был вызван метод. Это происходит динамически — никаких предварительных объявлений атрибутов в Python не требуется. Экземпляр хранит свои собственные данные, и self всегда ссылается именно на него.Таким образом, присваивание через
self не влияет на атрибуты класса, если такие были, и не затрагивает другие экземпляры. Это ключевое отличие между атрибутами класса и экземпляра: одни общие для всех объектов, другие — индивидуальны.👍1👎1
  🔍 Что выведет код?
  Anonymous Quiz
    13%
    class-level
      
    16%
    instance-level
      
    55%
    modified-instance
      
    15%
    Error
      
    👍4👎1
  В приведённой задаче у класса MyClass есть атрибут attr на уровне класса, но при создании экземпляра (obj = MyClass()) в конструкторе init создаётся атрибут экземпляра с тем же именем — self.attr = "instance-level". Это значит, что у obj теперь есть собственный атрибут attr, который перекрывает одноимённый атрибут класса. Затем мы ещё раз меняем значение этого атрибута напрямую: obj.attr = "modified-instance" — и именно это значение теперь хранится в объекте.
👍3👏1
  Какой из следующих методов НЕ является методом перегрузки операций в Python?
  Anonymous Quiz
    8%
    __add__
      
    8%
    __sub__
      
    13%
    __mul__
      
    71%
    __combine__
      
    👍1👎1
  Методы 
__add__, __sub__ и __mul__ являются магическими методами Python, используемыми для перегрузки операторов сложения (+), вычитания (-) и умножения (*) соответственно. Метод __combine__ не является стандартным магическим методом в Python и не используется для перегрузки операторов.👏2👎1
  😱2👎1
  В 
— Если мы передаем итерируемый объект без явного индекса (как список или кортеж), pandas создаёт индекс сам — по порядку элементов;
— Но для этого pandas должен полагаться на порядок элементов.
Множество
  pandas.Series() можно передавать различные итерируемые объекты, включая списки, кортежи, массивы NumPy и словари. Но:— Если мы передаем итерируемый объект без явного индекса (как список или кортеж), pandas создаёт индекс сам — по порядку элементов;
— Но для этого pandas должен полагаться на порядок элементов.
Множество
my_set — неупорядоченная структура. То есть Python не гарантирует порядок элементов внутри множества, даже если при создании кажется, что порядок есть.В каком порядке интерпретатор ищет атрибут по цепочке классов и объектов?
  Anonymous Quiz
    28%
    Суперкласс(-ы) → Класс → Экземпляр
      
    67%
    Экземпляр → Класс → Суперкласс(-ы)
      
    1%
    Порядок зависит от выделенной памяти
      
    4%
    Одновременно в экземпляре, классе и суперклассе(-ах)
      
    🤡2👍1
  Интерпретатор Python ищет атрибуты в порядке Экземпляр → Класс → Суперклассы, потому что это отражает модель наследования и переопределения в объектно-ориентированном программировании.
👍2🌭1
  🌱 Как по умолчанию называется первый аргумент функции?
  Anonymous Quiz
    17%
    args
      
    13%
    __init__
      
    30%
    self
      
    40%
    У него нет унифицированного названия
      
    👎32💩5
  В Python, когда ты определяешь метод в классе, первый аргумент по умолчанию называется self. Он указывает на сам объект, экземпляр класса, через который вызывается этот метод. Это соглашение принято для всех методов в классах, включая конструктор init.
class Dog:
def __init__(self, name):
self.name = name # 'self' ссылается на конкретный экземпляр Dog
def bark(self):
print(f"{self.name} говорит: Гав!")
dog = Dog("Бобик")
dog.bark() # Бобик говорит: Гав!
🤡8🤣2👎1
  Метод 
Когда ты создаешь новый объект, например:
Интерпретатор Python выполняет следующие шаги:
— Создаётся новый объект класса Dog;
— Вызывается метод init, и в него передаются все аргументы, которые мы указали при создании объекта ("Бобик");
— Метод
__init__ — это так называемый метод-конструктор. Он автоматически вызывается при создании нового экземпляра класса. Основная его цель — инициализация объекта, то есть присваивание значений его атрибутам.Когда ты создаешь новый объект, например:
dog = Dog("Бобик")
Интерпретатор Python выполняет следующие шаги:
— Создаётся новый объект класса Dog;
— Вызывается метод init, и в него передаются все аргументы, которые мы указали при создании объекта ("Бобик");
— Метод
__init__ инициализирует атрибуты объекта (например, устанавливает имя собаки) и может выполнять другие действия, связанные с подготовкой объекта к использованию.👍3👎1
  🔍  В чём разница между встроенными методами __new__ и __init__?
  Anonymous Quiz
    32%
    __new__ вызывается после создания объекта, __init__ — перед
      
    9%
    __new__ получает экземпляр (self), __init__ — класс (cls)
      
    43%
    __new__ возвращает Новый объект (cls(…)), __init__ — None
      
    17%
    Ничего из перечисленного
      
    👍8👎1🤡1