Python | Вопросы собесов @python_easy_ru Channel on Telegram

Python | Вопросы собесов

@python_easy_ru


Разбираем вопросы с собеседований на Python разработчика. Django, Flask, FastApi

Реклама: @easyoffer_adv
Решай тесты - t.me/+20tRfhrwPpM4NDQy

Нарешивай задачи - t.me/+nsl4meWmhfQwNDVi
Ищи работу - t.me/+cXGKkrOY2-w3ZTky

Python | Вопросы собесов (Russian)

Добро пожаловать в канал Python | Вопросы собесов! Здесь мы разбираем вопросы, которые могут встретиться на собеседованиях для Python разработчиков. Если вы интересуетесь Django, Flask, или FastApi, то вы попали по адресу. На нашем канале вы найдете полезные материалы, советы и рекомендации по подготовке к собеседованию. Мы поможем вам успешно пройти собеседование и получить желаемую работу в сфере Python разработки. Кроме того, на нашем канале есть возможность размещения рекламы, а также ссылки на тесты, задачи и вакансии для Python разработчиков. Присоединяйтесь к нам и станьте профессионалом в области Python разработки!

Python | Вопросы собесов

22 Nov, 09:10


🤔 Что такое @dataclass?

Это декоратор, предоставленный модулем dataclasses, который автоматически генерирует специальные методы, такие как __init__, __repr__, __eq__, и другие, для вашего класса. Это упрощает создание классов, предназначенных для хранения данных, устраняя необходимость писать много шаблонного кода.

🚩Зачем нужен

🟠Упрощение кода
Автоматически генерирует методы, сокращая шаблонный код.
🟠Читабельность
Делает код более чистым и легким для понимания.
🟠Удобство
Обеспечивает удобные и мощные возможности для работы с данными.

🚩Как использовать

Нужно импортировать его из модуля dataclasses и применить к классу. Внутри класса достаточно определить только поля данных.
from dataclasses import dataclass

@dataclass
class Person:
name: str
age: int

# Примеры использования
person1 = Person(name="Alice", age=30)
person2 = Person(name="Bob", age=25)

print(person1) # Вывод: Person(name='Alice', age=30)
print(person2) # Вывод: Person(name='Bob', age=25)
print(person1 == person2) # Вывод: False


🚩Автоматически генерируемые методы

🟠`__init__`
Инициализирует объект с заданными значениями атрибутов.
🟠`__repr__`
Возвращает строковое представление объекта, удобное для отладки.
🟠`__eq__`
Сравнивает объекты на равенство по их атрибутам.
🟠`__lt__`, `__le__`, `__gt__`, `__ge__`
Могут быть сгенерированы для сравнения объектов (если указано).

🚩Настройка поведения

Вы можете настроить поведение @dataclass с помощью параметров, таких как order, frozen, и других.

🟠`order=True`
Генерирует методы для сравнения объектов.
🟠`frozen=True`
Делает экземпляры неизменяемыми (immutable).

Пример
from dataclasses import dataclass

@dataclass(order=True, frozen=True)
class Person:
name: str
age: int

person1 = Person(name="Alice", age=30)
person2 = Person(name="Bob", age=25)

print(person1 > person2) # Вывод: True (поскольку 'Alice' > 'Bob' по алфавиту, если имена равны, сравниваются возраста)
# person1.age = 31 # Ошибка: FrozenInstanceError (поскольку класс заморожен)


🚩Поля данных и их настройки

Вы можете использовать функцию field() для настройки отдельных полей, например, для указания значений по умолчанию или исключения полей из методов __repr__, __eq__, и других.
from dataclasses import dataclass, field

@dataclass
class Person:
name: str
age: int = 0
address: str = field(default="Unknown", repr=False)

person = Person(name="Alice")
print(person) # Вывод: Person(name='Alice', age=0)


Ставь 👍 и забирай 📚 Базу знаний

Python | Вопросы собесов

21 Nov, 16:10


🤔 Что такое итератор?

Итератор в Python — это объект, который поддерживает метод `__iter__()` и `__next__()` для последовательного перебора элементов коллекции. Итераторы используются для работы с циклами и обеспечивают ленивую генерацию данных, не загружая их все сразу в память. Каждый вызов метода `next()` возвращает следующий элемент, а при отсутствии элементов вызывается исключение `StopIteration`. Итераторы полезны для работы с большими данными и потоками данных.

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний

Python | Вопросы собесов

21 Nov, 09:10


🤔 Что такое @staticmethod?

Используется для создания статических методов в классе. Статический метод — это метод, который не зависит от состояния экземпляра класса и может быть вызван напрямую на классе, не создавая экземпляр. Такие методы обычно используются для выполнения действий, которые логически связаны с классом, но не требуют доступа к его экземплярам или класс-методу.

🚩Зачем нужен

🟠Организация кода
Статические методы позволяют логически группировать функции, которые имеют отношение к классу, но не требуют доступа к его данным.
🟠Удобство использования
Они могут быть вызваны без создания экземпляра класса, что удобно для утилитарных функций.
🟠Читабельность и структуризация
Помогают держать код более организованным, особенно когда методы имеют логическую связь с классом, но не требуют доступа к его атрибутам или методам.

🚩Как использовать

Для создания статического метода, нужно использовать декоратор @staticmethod перед определением метода. В отличие от обычных методов класса, статический метод не принимает параметр self.
class MathUtils:
@staticmethod
def add(a, b):
return a + b

@staticmethod
def multiply(a, b):
return a * b

# Вызов статических методов
print(MathUtils.add(5, 3)) # Вывод: 8
print(MathUtils.multiply(5, 3)) # Вывод: 15


Пример использования статического метода для валидации
Здесь метод is_valid_email проверяет, является ли строка допустимым email адресом. Поскольку этот метод не требует доступа к состоянию экземпляра класса, его логично сделать статическим.
class Validator:
@staticmethod
def is_valid_email(email):
return "@" in email and "." in email

# Вызов статического метода
print(Validator.is_valid_email("[email protected]")) # Вывод: True
print(Validator.is_valid_email("invalid-email")) # Вывод: False


🚩Сравнение с другими методами

🟠Обычные методы
Принимают параметр self, который указывает на текущий экземпляр класса.
🟠Методы класса
Принимают параметр cls, который указывает на сам класс, и могут изменять состояние класса.
🟠Статические методы
Не принимают ни self, ни cls, что делает их более похожими на обычные функции, но логически сгруппированными в классе.

Пример для сравнения:
class Example:
def instance_method(self):
print("This is an instance method")

@classmethod
def class_method(cls):
print("This is a class method")

@staticmethod
def static_method():
print("This is a static method")

# Создание экземпляра класса
obj = Example()

# Вызов методов
obj.instance_method() # Вывод: This is an instance method
Example.class_method() # Вывод: This is a class method
Example.static_method() # Вывод: This is a static method


Ставь 👍 и забирай 📚 Базу знаний

Python | Вопросы собесов

20 Nov, 19:29


– Помощь с pet-проектом
– Составление roadmap
– Общая консультация
– Проведение код-ревью и mock-собеседования
– Помощь с трудоустройством

Все это и многое другое может Ментор. Он обеспечит вам необходимый boost, ускорит и упростит вход в IT.

🔥 Здесь размещен список менторов, и многие из них предлагают бесплатную первую консультацию

Python | Вопросы собесов

20 Nov, 16:10


🤔 Какие есть типы данных в Python?

В Python существует несколько встроенных типов данных: числовые типы (int, float, complex), строки (str), булевы значения (bool), списки (list), кортежи (tuple), множества (set) и словари (dict). Также есть типы для работы с бинарными данными, такие как bytes и bytearray. Кроме того, существуют пользовательские типы, которые можно создавать с помощью классов. Python поддерживает динамическую типизацию, где тип переменной определяется автоматически при присваивании значения.

Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚Базу Знаний

Python | Вопросы собесов

20 Nov, 09:10


🤔 Методы __enter__ и __exit__?

Используются для поддержки менеджеров контекста. Менеджеры контекста позволяют выполнять подготовительные и завершающие действия вокруг блока кода, используя конструкцию with. Это полезно для автоматического управления ресурсами, такими как открытие и закрытие файлов, управление соединениями с базами данных и т. д.

🟠Метод `enter`
Выполняет действия, которые должны произойти в начале блока with. Этот метод должен возвращать объект, который будет связан с переменной после оператора as.

🟠Метод `exit`
Выполняет действия, которые должны произойти в конце блока with, даже если в блоке произошло исключение. Он принимает три аргумента: тип исключения, значение исключения и трассировку (traceback). Если исключение не произошло, все три аргумента будут равны None.
class FileManager:
def __init__(self, filename, mode):
self.filename = filename
self.mode = mode
self.file = None

def __enter__(self):
self.file = open(self.filename, self.mode)
return self.file

def __exit__(self, exc_type, exc_value, traceback):
if self.file:
self.file.close()

# Примеры использования
with FileManager('example.txt', 'w') as f:
f.write('Hello, World!')

# Пример с обработкой исключений
try:
with FileManager('example.txt', 'r') as f:
content = f.read()
print(content)
except Exception as e:
print(f"An error occurred: {e}")


Пример с обработкой ресурсов
class DatabaseConnection:
def __init__(self, db_name):
self.db_name = db_name
self.connection = None

def __enter__(self):
self.connection = self.connect_to_database(self.db_name)
return self.connection

def __exit__(self, exc_type, exc_value, traceback):
if self.connection:
self.connection.close()

def connect_to_database(self, db_name):
# Реализация соединения с базой данных (псевдокод)
print(f"Connecting to database {db_name}")
return f"Connection to {db_name}"

def close(self):
# Реализация закрытия соединения (псевдокод)
print("Closing the connection")

# Примеры использования
with DatabaseConnection('my_database') as conn:
print(conn)
# Выполнение операций с базой данных

# Пример с обработкой исключений
try:
with DatabaseConnection('my_database') as conn:
raise ValueError("Some error occurred")
except Exception as e:
print(f"An error occurred: {e}")


Ставь 👍 и забирай 📚 Базу знаний

Python | Вопросы собесов

19 Nov, 16:10


🤔 Как пропустить заблокированные поля в БД при использовании select?

Чтобы пропустить заблокированные поля в БД при выполнении запроса `SELECT`, можно:
1. Явно указать в запросе только те столбцы, которые доступны, вместо использования `SELECT *`.
2. Убедиться, что права доступа на уровне пользователя или роли не запрещают чтение нужных столбцов.
3. Использовать средства обработки ошибок в коде, чтобы обрабатывать исключения, если доступ к полю невозможен.
Это помогает избежать ошибок и выполнить запрос успешно.


Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний

Python | Вопросы собесов

19 Nov, 09:10


🤔 Методы getitem и setitem и delitem?

Позволяют объектам вашего класса работать как контейнеры, подобные спискам или словарям. Они отвечают за доступ к элементам, установку значений элементов и удаление элементов по индексам или ключам.

🟠Метод `getitem`
Используется для доступа к элементам объекта по индексу или ключу. Он вызывается, когда вы используете синтаксис квадратных скобок для доступа к элементу.
class MyList:
def __init__(self, items):
self.items = items

def __getitem__(self, index):
return self.items[index]

# Примеры использования
my_list = MyList([1, 2, 3, 4])
print(my_list[0]) # Вывод: 1
print(my_list[2]) # Вывод: 3


🟠Метод `setitem`
Используется для установки значений элементов по индексу или ключу. Он вызывается, когда вы используете синтаксис квадратных скобок для установки значения элемента.
class MyList:
def __init__(self, items):
self.items = items

def __setitem__(self, index, value):
self.items[index] = value

# Примеры использования
my_list = MyList([1, 2, 3, 4])
my_list[1] = 10
print(my_list.items) # Вывод: [1, 10, 3, 4]


🟠Метод `delitem`
Используется для удаления элементов по индексу или ключу. Он вызывается, когда вы используете синтаксис del с квадратными скобками.
class MyList:
def __init__(self, items):
self.items = items

def __delitem__(self, index):
del self.items[index]

# Примеры использования
my_list = MyList([1, 2, 3, 4])
del my_list[2]
print(my_list.items) # Вывод: [1, 2, 4]


Пример использования всех методов вместе
class CustomDict:
def __init__(self):
self.data = {}

def __getitem__(self, key):
return self.data[key]

def __setitem__(self, key, value):
self.data[key] = value

def __delitem__(self, key):
del self.data[key]

# Примеры использования
custom_dict = CustomDict()
custom_dict['a'] = 1
custom_dict['b'] = 2
print(custom_dict['a']) # Вывод: 1
print(custom_dict['b']) # Вывод: 2

del custom_dict['a']
print(custom_dict.data) # Вывод: {'b': 2}


Ставь 👍 и забирай 📚 Базу знаний

Python | Вопросы собесов

18 Nov, 16:10


🤔 Какие основные HTTP методы знаешь?

Основные HTTP методы включают:
- `GET` для получения данных с сервера.
- `POST` для отправки данных на сервер (создание ресурса).
- `PUT` для обновления или создания ресурса.
- `DELETE` для удаления ресурса.
- `PATCH` для частичного обновления ресурса.
- `HEAD` для получения заголовков без тела ответа.
- `OPTIONS` для получения информации о поддерживаемых методах.
Эти методы обеспечивают основное взаимодействие клиента и сервера.


Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний