Please open Telegram to view this post
VIEW IN TELEGRAM
В Django URL-шаблоны определяют, какие view-функции обрабатывают запросы по конкретным путям. Они задаются в
Маршруты проверяются сверху вниз. Можно группировать URL через
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
urls.py
через path()
или re_path()
(для regex).
from django.urls import path
from . import views
urlpatterns = [
path('articles/', views.article_list), # Обработка /articles/
path('articles/<int:id>/', views.article_detail), # Динамический параметр id
]
Маршруты проверяются сверху вниз. Можно группировать URL через
include()
, передавая часть маршрутизации в приложение. Именованные пути (name='article-list') позволяют генерировать URL без жесткого кодирования.Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Команда
Если нужно отменить несколько коммитов, можно указать диапазон:
После выполнения откроется редактор для сообщения нового коммита. Используется, когда нужно безопасно отменить изменения в истории, не перезаписывая его.
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
git revert
отменяет изменения указанного коммита, создавая новый коммит с инвертированными изменениями.
git revert <commit-hash> # Создает новый коммит, отменяющий изменения
Если нужно отменить несколько коммитов, можно указать диапазон:
git revert <oldest-commit-hash>..<latest-commit-hash> # Отменяет все коммиты в диапазоне
После выполнения откроется редактор для сообщения нового коммита. Используется, когда нужно безопасно отменить изменения в истории, не перезаписывая его.
Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
Для защиты API применяют аутентификацию и авторизацию. Основные методы:
Дополнительно используют HTTPS, ограничение запросов (rate limiting) и проверку CORS. Для сложных сценариев подходят OAuth2 или библиотеки вроде
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
# JWT-токены (FastAPI/Flask)
from fastapi.security import OAuth2PasswordBearer
oauth2_scheme = OAuth2PasswordBearer(tokenUrl="token")
# API-ключи в заголовках
API_KEY = "secret_key"
def validate_key(api_key: str):
if api_key != API_KEY:
raise HTTPException(status_code=403)
Дополнительно используют HTTPS, ограничение запросов (rate limiting) и проверку CORS. Для сложных сценариев подходят OAuth2 или библиотеки вроде
Authlib
.Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Паттерн Iterator в Python реализуется через методы
Встроенные типы (list, dict) уже поддерживают итерацию. Для ленивых вычислений удобны генераторы (yield).
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
__iter__()
и __next__()
. Класс становится итерируемым, если __iter__()
возвращает сам объект, а __next__()
возвращает следующий элемент или вызывает StopIteration
.
class Counter:
def __init__(self, max):
self.max = max
self.current = 0
def __iter__(self):
return self
def __next__(self):
if self.current >= self.max:
raise StopIteration
self.current += 1
return self.current - 1
Встроенные типы (list, dict) уже поддерживают итерацию. Для ленивых вычислений удобны генераторы (yield).
Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
Для измерения покрытия кода тестами используется библиотека
Метрика показывает, какая часть кода была выполнена во время тестов. Можно исключить файлы через
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
coverage
.
coverage run -m pytest # Запуск тестов с отслеживанием покрытия
coverage report # Вывод отчета в консоль
coverage html # Генерация HTML-отчета
Метрика показывает, какая часть кода была выполнена во время тестов. Можно исключить файлы через
.coveragerc
. Оптимальное покрытие — 80-100%, но важнее осмысленность тестов.Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Функция
Эквивалентна одновременному выполнению
Полезна при разбиении значений на части (например, секунды в минуты и секунды).
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
divmod()
принимает два числа и возвращает кортеж из частного и остатка от деления.
result = divmod(10, 3) # (3, 1)
Эквивалентна одновременному выполнению
//
(целочисленное деление) и %
(остаток). Работает с целыми и вещественными числами.
divmod(10.5, 3) # (3.0, 1.5)
Полезна при разбиении значений на части (например, секунды в минуты и секунды).
Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
Для проверки наличия элемента в кортеже используется оператор
Аналогично работает с
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
in
, который возвращает True
или False
.
my_tuple = (1, 2, 3, 'a', 'b')
contains_two = 2 in my_tuple # True
contains_z = 'z' in my_tuple # False
Аналогично работает с
not in
для проверки отсутствия. Метод эффективен и читаем, подходит для любых итерируемых объектов.Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Декораторы для проверки прав доступа оборачивают функции, проверяя аутентификацию или права пользователя перед выполнением.
Пример применения:
Такой подход централизует проверки и сохраняет чистоту бизнес-логики.
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
def admin_required(func):
def wrapper(user, *args, **kwargs):
if not user.is_admin:
raise PermissionError("Admin access required")
return func(user, *args, **kwargs)
return wrapper
Пример применения:
@admin_required
def delete_user(user, username):
# Логика удаления
Такой подход централизует проверки и сохраняет чистоту бизнес-логики.
Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
Чтобы прочитать файл с определенной позиции, можно использовать метод
Метод
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
seek()
для перемещения файлового указателя перед чтением. После установки позиции данные считываются методом read()
.
with open('file.txt', 'r') as file:
file.seek(100) # Переместить указатель на 100-й байт
data = file.read() # Чтение с текущей позиции
Метод
seek()
принимает смещение в байтах, а второй аргумент (необязательный) определяет точку отсчета (0 — начало файла, 1 — текущая позиция, 2 — конец файла).Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Метод
По умолчанию
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
__dir__()
возвращает список атрибутов и методов объекта. Его можно переопределить в пользовательских классах, чтобы изменить поведение встроенной функции dir()
.
class Example:
def __dir__(self):
return ['custom_attr', 'custom_method']
obj = Example()
print(dir(obj)) # Выведет ['custom_attr', 'custom_method']
По умолчанию
__dir__()
включает атрибуты класса, его методы и унаследованные члены. Переопределение полезно для ограничения или кастомизации вывода.Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
Функция
В Python 3.10+ рекомендуется использовать
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
asyncio.get_event_loop()
возвращает текущий событийный цикл для данного контекста выполнения. Если цикла нет, создаёт новый и устанавливает его как текущий.
loop = asyncio.get_event_loop() # Получает текущий цикл или создаёт новый
В Python 3.10+ рекомендуется использовать
asyncio.run()
для верхнеуровневого кода вместо ручного управления циклом. Метод устарел для создания новых циклов в пользу asyncio.new_event_loop()
.Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Оператор
Для строк проверяет наличие подстроки:
Для списков и кортежей проверяет наличие элемента:
Для словарей проверяет наличие ключа:
Также
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
in
проверяет вхождение элемента в последовательность (список, кортеж, строку) или наличие ключа в словаре. Возвращает True
, если элемент найден, иначе False
. Для строк проверяет наличие подстроки:
if 'hello' in 'hello world':
# True, так как подстрока 'hello' есть в строке
Для списков и кортежей проверяет наличие элемента:
if 2 in [1, 2, 3]:
# True, так как 2 есть в списке
Для словарей проверяет наличие ключа:
if 'key' in {'key': 'value'}:
# True, так как ключ 'key' существует
Также
in
работает с генераторами и множествами. Сложность операции зависит от типа данных: O(1) для словарей и множеств, O(n) для списков и строк.Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
Условие if name == "__main__": определяет, выполняется ли скрипт напрямую или импортируется как модуль. Код внутри этого блока запускается только при прямом запуске файла.
Если файл импортирован, код вне этого блока (функции, классы) будет доступен, но код внутри
Ставь👍 , если было полезно!
Больше ответов на сайте👈
✈️ Python собеседования
def some_function():
print("This is a function")
if __name__ == "__main__":
print("Script executed directly")
some_function()
Если файл импортирован, код вне этого блока (функции, классы) будет доступен, но код внутри
if
не выполнится. Это полезно для тестирования и разделения логики модуля и его запуска.Ставь
Больше ответов на сайте
Please open Telegram to view this post
VIEW IN TELEGRAM