Python: задачки и вопросы
رفتن به کانال در Telegram
Вопросы и задачки для подготовки к собеседованиям и прокачки навыков Разместить рекламу: @tproger_sales_bot Правила общения: https://tprg.ru/rules Другие каналы: @tproger_channels Другие наши проекты: https://tprg.ru/media
نمایش بیشتر7 128
مشترکین
-424 ساعت
+87 روز
-230 روز
آرشیو پست ها
В
pandas.Series() можно передавать различные итерируемые объекты, включая списки, кортежи, массивы NumPy и словари. Но:
— Если мы передаем итерируемый объект без явного индекса (как список или кортеж), pandas создаёт индекс сам — по порядку элементов;
— Но для этого pandas должен полагаться на порядок элементов.
Множество my_set — неупорядоченная структура. То есть Python не гарантирует порядок элементов внутри множества, даже если при создании кажется, что порядок есть.Методы
__add__, __sub__ и __mul__ являются магическими методами Python, используемыми для перегрузки операторов сложения (+), вычитания (-) и умножения (*) соответственно. Метод __combine__ не является стандартным магическим методом в Python и не используется для перегрузки операторов.Какой из следующих методов НЕ является методом перегрузки операций в Python?
В приведённой задаче у класса MyClass есть атрибут attr на уровне класса, но при создании экземпляра (obj = MyClass()) в конструкторе init создаётся атрибут экземпляра с тем же именем — self.attr = "instance-level". Это значит, что у obj теперь есть собственный атрибут attr, который перекрывает одноимённый атрибут класса. Затем мы ещё раз меняем значение этого атрибута напрямую: obj.attr = "modified-instance" — и именно это значение теперь хранится в объекте.
Когда в методе используется
self.attr = ..., Python создает (или обновляет) атрибут у конкретного экземпляра, на котором был вызван метод. Это происходит динамически — никаких предварительных объявлений атрибутов в Python не требуется. Экземпляр хранит свои собственные данные, и self всегда ссылается именно на него.
Таким образом, присваивание через self не влияет на атрибуты класса, если такие были, и не затрагивает другие экземпляры. Это ключевое отличие между атрибутами класса и экземпляра: одни общие для всех объектов, другие — индивидуальны.🔍 Что происходит, когда метод класса в Python выполняет присваивание значения с использованием self, например self.attr = 10?
Атрибут
category в классе C1 создаётся внутри метода (__init__), а значит, он становится атрибутом экземпляра, а не атрибутом класса. Такой атрибут доступен только после создания объекта через C3(), и обращаться к нему нужно через сам объект (obj.category), а не через класс (C3.category).
Когда в коде пишется print(C3.category), Python пытается найти атрибут класса с именем category у C3 или его родителей. Но такого атрибута нет — category создаётся только при вызове конструктора (__init__). Поэтому попытка обращения к C3.category приводит к ошибке AttributeError.Атрибуты, присоединенные к экземплярам, сохраняются только для этих одиночных экземпляров, но атрибуты, присоединенные к классам, разделяются всеми их подклассами и экземплярами.
Да, в Python подкласс может иметь двух и более суперклассов — это называется множественное наследование.
Пример:
class Flyer:
def fly(self):
print(«Я могу летать»)
class Swimmer:
def swim(self):
print(«Я могу плавать»)
class Duck(Flyer, Swimmer):
pass
d = Duck()
d.fly() # Я могу летать
d.swim() # Я могу плавать
Здесь Duck — подкласс, который наследует и Flyer, и Swimmer.
Python использует алгоритм MRO (Method Resolution Order), чтобы определить порядок, в котором ищутся методы при множественном наследовании.
Потенциальные сложности:
• Если оба родителя имеют методы с одинаковыми именами, нужно понимать в каком порядке они вызываются.
• Иногда нужно явно использовать super(), особенно в ромбовидном наследовании, чтобы избежать дублирования.🌱 Может ли в Python подкласс иметь двух родителей — суперклассов?
Предоставлять ли объяснения к задаче сразу? (пост может выходить одновременно с задачей)
Когда создаёшь pd.Series из списка кортежей, каждый кортеж становится отдельным элементом серии. В результате, вывод будет выглядеть так:
0 (120, 41, 26)
1 (196, 165, 45)
dtype: object
اکنون در دسترس! پژوهش تلگرام ۲۰۲۵ — مهمترین بینشهای سال 
