Python: задачки и вопросы
7.74K subscribers
1.19K photos
1 video
1 file
91 links
Вопросы и задачки для подготовки к собеседованиям и прокачки навыков

Разместить рекламу: @tproger_sales_bot

Правила общения: https://tprg.ru/rules

Другие каналы: @tproger_channels

Другие наши проекты: https://tprg.ru/media
Download Telegram
🌱 Что выведет код?
Anonymous Quiz
8%
None
82%
'food'
10%
AttributeError
1%
TypeError
👍4👎1🤬1
Атрибуты, присоединенные к экземплярам, сохраняются только для этих одиночных экземпляров, но атрибуты, присоединенные к классам, разделяются всеми их подклассами и экземплярами.
👍1
🔍 Что выведет код?
Anonymous Quiz
55%
'food'
5%
TypeError
33%
AttributeError
7%
None
👍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
Когда в методе используется self.attr = ..., Python создает (или обновляет) атрибут у конкретного экземпляра, на котором был вызван метод. Это происходит динамически — никаких предварительных объявлений атрибутов в Python не требуется. Экземпляр хранит свои собственные данные, и self всегда ссылается именно на него.

Таким образом, присваивание через self не влияет на атрибуты класса, если такие были, и не затрагивает другие экземпляры. Это ключевое отличие между атрибутами класса и экземпляра: одни общие для всех объектов, другие — индивидуальны.
👍1👎1
🔍 Что выведет код?
Anonymous Quiz
13%
class-level
17%
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
🌱 Что выведет код?
Anonymous Quiz
59%
1
19%
2
11%
ValueError
12%
TypeError
😱2👎1
В pandas.Series() можно передавать различные итерируемые объекты, включая списки, кортежи, массивы NumPy и словари. Но:
— Если мы передаем итерируемый объект без явного индекса (как список или кортеж), pandas создаёт индекс сам — по порядку элементов;
— Но для этого pandas должен полагаться на порядок элементов.

Множество my_set — неупорядоченная структура. То есть Python не гарантирует порядок элементов внутри множества, даже если при создании кажется, что порядок есть.
Интерпретатор 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
Метод __init__ — это так называемый метод-конструктор. Он автоматически вызывается при создании нового экземпляра класса. Основная его цель — инициализация объекта, то есть присваивание значений его атрибутам.

Когда ты создаешь новый объект, например:

dog = Dog("Бобик")


Интерпретатор Python выполняет следующие шаги:
— Создаётся новый объект класса Dog;
— Вызывается метод init, и в него передаются все аргументы, которые мы указали при создании объекта ("Бобик");
— Метод __init__ инициализирует атрибуты объекта (например, устанавливает имя собаки) и может выполнять другие действия, связанные с подготовкой объекта к использованию.
👍3👎1