Python | Вопросы собесов
Cайт: easyoffer.ru Реклама: @easyoffer_adv ВП: @easyoffer_vp Тесты t.me/+20tRfhrwPpM4NDQy Задачи t.me/+nsl4meWmhfQwNDVi Вакансии t.me/+cXGKkrOY2-w3ZTky
Ko'proq ko'rsatish📈 Telegram kanali Python | Вопросы собесов analitikasi
Python | Вопросы собесов (@python_easy_ru) Rus til segmentidagi kanali faol ishtirokchi. Hozirda hamjamiyat 13 104 obunachidan iborat bo'lib, Texnologiyalar & Aralashmalar toifasida 9 734-o'rinni va Rossiya mintaqasida 50 704-o'rinni egallagan.
📊 Auditoriya ko‘rsatkichlari va dinamika
невідомо sanasidan buyon loyiha tez o‘sib, 13 104 obunachiga ega bo‘ldi.
10 Iyun, 2026 dagi oxirgi ma’lumotlarga ko‘ra kanal barqaror faollikka ega. Oxirgi 30 kunda obunachilar soni -55 ga, so‘nggi 24 soatda esa 1 ga o‘zgardi va umumiy qamrov yuqori darajada qolmoqda.
- Tasdiqlash holati: Tasdiqlanmagan
- Jalb etish (ER): Auditoriya o‘rtacha 8.86% darajada jalb etiladi. Nashrdan keyingi dastlabki 24 soatda kontent odatda umumiy obunachilar sonining 5.51% ini tashkil etuvchi reaksiyalarni to‘playdi.
- Post qamrovi: Har bir post o‘rtacha 1 161 marta ko‘riladi; birinchi sutkada odatda 722 ta ko‘rish yig‘iladi.
- Reaksiyalar va o‘zaro ta’sir: Auditoriya faol: har bir postga o‘rtacha 3 ta reaksiya keladi.
- Tematik yo‘nalishlar: Kontent ставь, модуль, строка, docker, alice kabi asosiy mavzularga jamlangan.
📝 Tavsif va kontent siyosati
Muallif resursni shaxsiy fikrni ifoda etish maydoni sifatida ta’riflaydi:
“Cайт: easyoffer.ru
Реклама: @easyoffer_adv
ВП: @easyoffer_vp
Тесты t.me/+20tRfhrwPpM4NDQy
Задачи t.me/+nsl4meWmhfQwNDVi
Вакансии t.me/+cXGKkrOY2-w3ZTky”
Yuqori yangilanish chastotasi (oxirgi ma’lumot 11 Iyun, 2026 da olingan) sababli kanal doimo dolzarb va katta qamrovli bo‘lib qoladi. Analitika auditoriya kontent bilan faol hamkorlik qilishini, uni Texnologiyalar & Aralashmalar toifasidagi muhim ta’sir nuqtasiga aylantirishini ko‘rsatadi.
iter(). Итераторы – это объекты, которые реализуют метод __iter__() и метод __next__(). Давайте рассмотрим, как это работает на примере.
🤔 Пример создания итератора
Рассмотрим список, который является одной из стандартных коллекций в Python:
my_list = [1, 2, 3, 4, 5]
Чтобы создать итератор из этого списка, используем функцию iter():
my_iterator = iter(my_list)
Теперь my_iterator – это итератор, который можно использовать для поочередного доступа к элементам списка.
🤔 Использование итератора
Мы можем использовать функцию next() для получения следующего элемента итератора:
print(next(my_iterator)) # Выводит: 1
print(next(my_iterator)) # Выводит: 2
print(next(my_iterator)) # Выводит: 3
Когда элементы коллекции заканчиваются, next() вызовет исключение StopIteration.
🤔 Итераторы и циклы
Обычно итераторы используются в сочетании с циклами for, что упрощает работу с ними:
for item in my_iterator:
print(item)
Если попытаться использовать итератор повторно после его исчерпания, он больше не будет выдавать элементы:
my_iterator = iter(my_list)
for item in my_iterator:
print(item)
# Повторное использование того же итератора:
for item in my_iterator:
print(item) # Ничего не выведет, так как итератор уже исчерпан
🤔 Создание собственного итератора
Можно создать собственный итератор, определив класс с методами __iter__() и __next__().
Пример:
class MyIterator:
def __init__(self, data):
self.data = data
self.index = 0
def __iter__(self):
return self
def __next__(self):
if self.index < len(self.data):
result = self.data[self.index]
self.index += 1
return result
else:
raise StopIteration
my_iterable = MyIterator([10, 20, 30])
for item in my_iterable:
print(item)
В этом примере мы создали собственный итератор, который перебирает элементы списка [10, 20, 30].
🤔 Краткий итог:
1️⃣ Итератор можно создать из коллекции с помощью функции iter().
2️⃣ Итераторы используют методы __iter__() и __next__() для поочередного доступа к элементам.
3️⃣ Итераторы обычно применяются в циклах for для удобства перебора элементов коллекции.
🔥 ТОП ВОПРОСОВ С СОБЕСОВ
🔒 База собесов | 🔒 База тестовыхclass Math:
def add(self, a, b, c=0):
return a + b + c
math = Math()
print(math.add(2, 3)) # 5
print(math.add(2, 3, 4)) # 9
В этом примере метод add может принимать два или три аргумента, что является примером неявной перегрузки.
2️⃣ Наследование и переопределение методов
Наследование и переопределение методов – это более распространенный и важный аспект полиморфизма в Python. Это когда методы в дочернем классе переопределяют поведение методов в базовом классе.
Пример:
class Animal:
def sound(self):
raise NotImplementedError("Subclass must implement abstract method")
class Dog(Animal):
def sound(self):
return "Woof"
class Cat(Animal):
def sound(self):
return "Meow"
def make_sound(animal):
print(animal.sound())
dog = Dog()
cat = Cat()
make_sound(dog) # Woof
make_sound(cat) # Meow
В этом примере класс Dog и класс Cat переопределяют метод sound базового класса Animal. Функция make_sound вызывает метод sound независимо от конкретного типа объекта.
🤔 Краткий итог:
1️⃣ Перегрузка методов позволяет использовать методы с различным числом аргументов.
2️⃣ Наследование и переопределение методов позволяет дочерним классам реализовывать или изменять поведение методов базового класса.
🔥 ТОП ВОПРОСОВ С СОБЕСОВ
🔒 База собесов | 🔒 База тестовыхabc (Abstract Base Classes), а абстрактные методы обозначаются декоратором @abstractmethod.
➕ Пример абстрактного класса
from abc import ABC, abstractmethod
class Animal(ABC):
@abstractmethod
def make_sound(self):
pass
@abstractmethod
def move(self):
pass
🤔 Реализация абстрактного класса
Абстрактный класс Animal определяет два абстрактных метода: make_sound и move. Эти методы не имеют реализации и должны быть реализованы в подклассах. Попробуем создать подклассы:
class Dog(Animal):
def make_sound(self):
return "Bark"
def move(self):
return "Run"
class Cat(Animal):
def make_sound(self):
return "Meow"
def move(self):
return "Jump"
Теперь мы можем создать объекты классов Dog и Cat и использовать их методы, не задумываясь о деталях реализации.
dog = Dog()
print(dog.make_sound()) # Вывод: "Bark"
print(dog.move()) # Вывод: "Run"
cat = Cat()
print(cat.make_sound()) # Вывод: "Meow"
print(cat.move()) # Вывод: "Jump"
🤔 Преимущества абстракции
1️⃣ Упрощение сложных систем: Абстракция помогает разбивать сложные системы на более управляемые части.
2️⃣ Повышение читабельности и поддерживаемости кода: Код становится более понятным, так как скрываются ненужные детали реализации.
3️⃣ Снижение зависимости кода: Изменения в реализации не влияют на пользователей класса, что позволяет более гибко изменять и расширять функциональность.
🤔 Подводя итог
Абстракция в ООП позволяет скрывать детали реализации и предоставлять простой интерфейс для взаимодействия с объектами. В Python абстракция достигается через абстрактные классы и методы, которые определяются с использованием модуля abc и декоратора @abstractmethod.
🤔Кратко:
Абстракция скрывает детали реализации и предоставляет простой интерфейс для использования объектов. В Python это реализуется с помощью абстрактных классов и методов.
🔥 ТОП ВОПРОСОВ С СОБЕСОВ
🔒 База собесов | 🔒 База тестовыхclass Dog:
def __init__(self, name):
self.name = name
def bark(self):
return f"{self.name} barks"
В этом примере Dog — это класс, который определяет, что у каждой собаки будет имя и метод bark().
🤔 Объект класса
Объект класса — это конкретный экземпляр класса, созданный на основе его шаблона. Он имеет реальные данные и может выполнять методы, определенные в классе.
my_dog = Dog("Rex")
print(my_dog.bark()) # Выведет: Rex barks
my_dog — это объект класса Dog. Он имеет конкретное имя "Rex" и может выполнять метод bark().
🤔 Основные отличия:
1️⃣ Определение vs. Реализация:
- Класс: Определяет свойства и поведение (методы).
- Объект: Реализует эти свойства и методы с конкретными данными.
2️⃣ Создание:
- Класс: Создается один раз и служит шаблоном.
- Объект: Можно создать множество объектов на основе одного класса.
3️⃣ Статические vs. Динамические:
- Класс: Статичен, определяет общую структуру.
- Объект: Динамичен, хранит конкретное состояние.
🤔 Пример для понимания:
class Car: def __init__(s, m, y): s.m, s.y = m, y
def drive(s): return f"The {s.m} from {s.y} is driving"
c1, c2 = Car("Toyota", 2020), Car("Honda", 2019)
print(c1.drive()) # The Toyota from 2020 is driving
print(c2.drive()) # The Honda from 2019 is driving
- Car — это класс.
- car1 и car2 — это объекты класса Car, каждый из которых имеет свои данные (модель и год выпуска).
🤔 Краткое объяснение
Класс — это шаблон для создания объектов, определяющий свойства и методы. Объект — это конкретный экземпляр класса с реальными данными и функциональностью.
🔥 ТОП ВОПРОСОВ С СОБЕСОВ
🔒 База собесов | 🔒 База тестовых__dict__. Этот словарь содержит пары ключ-значение, где ключ — это имя атрибута, а значение — его значение.
➕ Пример:
class MyClass:
def __init__(self, value):
self.value = value
obj = MyClass(42)
print(obj.__dict__) # Вывод: {'value': 42}
🤔 Хранение атрибутов и методов в классах
Классы в Python также используют словарь __dict__, чтобы хранить свои атрибуты и методы. Этот словарь доступен через атрибут __dict__ класса и содержит все атрибуты и методы класса.
➕ Пример:
class MyClass:
class_attribute = "Классовый атрибут"
def __init__(self, value):
self.value = value
def method(self):
return "Метод экземпляра"
print(MyClass.__dict__)
# Выводит словарь, содержащий class_attribute, __init__, method и другие служебные атрибуты
🤔 Атрибуты и методы наследуются
Когда вы создаете экземпляр класса, Python сначала проверяет наличие атрибута или метода в экземпляре объекта, а затем в его классе, и далее по цепочке наследования, если атрибут или метод не найден.
➕ Пример наследования:
class Parent:
def method(self):
return "Метод родителя"
class Child(Parent):
pass
child = Child()
print(child.method()) # Вывод: "Метод родителя"
🤔 Порядок поиска атрибутов и методов: MRO
Порядок разрешения методов (MRO) определяет, в каком порядке Python ищет атрибуты и методы. MRO можно получить с помощью метода mro() или атрибута __mro__.
➕ Пример получения MRO:
class A:
pass
class B(A):
pass
class C(A):
pass
class D(B, C):
pass
print(D.mro())
# Вывод: [<class '__main__.D'>, <class '__main__.B'>, <class '__main__.C'>, <class '__main__.A'>, <class 'object'>]
🤔 Специальные атрибуты класса
➕ `__dict__`: Содержит атрибуты и методы класса или экземпляра.
➕ `__mro__`: Кортеж, показывающий порядок разрешения методов.
➕ `__bases__`: Кортеж базовых классов, от которых наследуется класс.
➕ Пример специальных атрибутов:
class Parent:
pass
class Child(Parent):
pass
print(Child.__bases__) # Вывод: (<class '__main__.Parent'>,)
print(Child.__mro__) # Вывод: (<class '__main__.Child'>, <class '__main__.Parent'>, <class 'object'>)
🤔 Подводя итог
Атрибуты и методы экземпляров класса хранятся в словаре __dict__ экземпляра, а атрибуты и методы самого класса — в словаре __dict__ класса. Наследование и порядок разрешения методов (MRO) определяют, как Python ищет атрибуты и методы в иерархии классов.
🤔Кратко:
Атрибуты экземпляров хранятся в __dict__ объекта, а атрибуты и методы класса — в __dict__ класса. Порядок разрешения методов (MRO) определяет, как Python ищет атрибуты и методы.
🔥 ТОП ВОПРОСОВ С СОБЕСОВ
🔒 База собесов | 🔒 База тестовыхcls — это конвенциональное имя, используемое в методах классов для обозначения самого класса. Оно аналогично self, который используется для обозначения экземпляра класса в методах экземпляра.
🤔 Использование `cls` в методах класса
Методы класса (class methods) — это методы, которые получают сам класс в качестве первого аргумента вместо экземпляра класса. Такие методы определяются с использованием декоратора @classmethod.
🤔 Пример метода класса
class MyClass:
class_attribute = "Классовый атрибут"
def __init__(self, value):
self.instance_attribute = value # Атрибут экземпляра
@classmethod
def class_method(cls):
return cls.class_attribute
# Вызов метода класса
print(MyClass.class_method()) # Вывод: "Классовый атрибут"
🤔 Зачем нужен `cls`
1️⃣Доступ к классовым атрибутам и методам: Используя cls, вы можете получить доступ к атрибутам и методам самого класса.
2️⃣Изменение поведения класса: cls позволяет создавать методы, которые могут работать с классом, а не с конкретным экземпляром, что полезно для задач, связанных с настройкой или инициализацией классовых атрибутов.
3️⃣Создание альтернативных конструкторов: С помощью cls можно создавать альтернативные конструкторы, которые возвращают экземпляры класса различными способами.
🤔 Пример альтернативного конструктора
```python
class MyClass:
def init(self, value):
self.value = value
@classmethod
def from_string(cls, string):
value = int(string)
return cls(value)
➕ Создание экземпляра через альтернативный конструктор
obj = MyClass.from_string("42")
print(obj.value) # Вывод: 42
```
🤔 Различие между `cls` и `self`
➕`self`: Используется для методов экземпляра. Ссылается на конкретный экземпляр класса, через который вызван метод.
➕ `cls`: Используется для методов класса. Ссылается на сам класс, через который вызван метод.
🤔 Пример различий
class MyClass:
class_attribute = "Классовый атрибут"
def __init__(self, value):
self.instance_attribute = value
@classmethod
def class_method(cls):
return cls.class_attribute
def instance_method(self):
return self.instance_attribute
# Создание экземпляра
obj = MyClass(42)
# Вызов метода экземпляра
print(obj.instance_method()) # Вывод: 42
# Вызов метода класса
print(MyClass.class_method()) # Вывод: "Классовый атрибут"
🤔 Подводя итог
cls — это имя, используемое для обозначения самого класса в методах класса, определенных с помощью декоратора @classmethod. Оно позволяет работать с атрибутами и методами класса, а не конкретного экземпляра.
🤔 Кратко:
cls используется в методах класса для обозначения самого класса, как self используется для обозначения экземпляра класса.
🔥 ТОП ВОПРОСОВ С СОБЕСОВ
🔒 База собесов | 🔒 База тестовых
Endi mavjud! Telegram Tadqiqoti 2025 — yilning asosiy insaytlari 
