❓ Вопрос на собеседовании
Что такое методическое разрешение (MRO) в Python, как его проверить и зачем оно нужно?
Ответ ⬇️
Методическое разрешение (MRO) определяет порядок, в котором Python ищет методы и атрибуты в иерархии классов при наследовании. MRO важен для работы с множественным наследованием, так как помогает избежать конфликтов и гарантирует корректное разрешение зависимостей.
MRO можно проверить с помощью атрибута __mro__ или функции mro(). Python использует алгоритм C3-линеаризации для вычисления MRO.
Пример использования ⚙️
class A:
def method(self):
print("Метод класса A")
class B(A):
def method(self):
print("Метод класса B")
class C(A):
def method(self):
print("Метод класса C")
class D(B, C):
pass
print(D.__mro__) # (<class '__main__.D'>, <class '__main__.B'>, <class '__main__.C'>, <class '__main__.A'>, <class 'object'>)
d = D()
d.method() # Метод класса B
⌛ Что будет выведено при выполнении кода?
Пояснение ⬇️
Оператор is проверяет, указывают ли обе переменные на один и тот же объект в памяти. Переменные x и y ссылаются на один объект, поэтому x is y возвращает True. Переменная z — новый объект с тем же содержимым, но другой областью в памяти, поэтому x is z возвращает False.
🚀 Хотите создать своего Telegram-бота и ворваться в мир Python-разработки?
👨💻 На бесплатном открытом уроке 16 января вы узнаете, как за 2 часа создать функционального Telegram-бота с нуля:
— Установка и настройка Python-telegram-bot.
— Создание бота: от идеи до реализации.
— Расширение возможностей с дополнительными функциями.
🤖 Представьте, как ваш бот помогает автоматизировать задачи, такие как обработка данных, управление файлами и отправка электронных писем, а также открывает возможности для заработка! Начните путь востребованного разработчика уже сейчас.
👉 Регистрируйтесь на вебинар в преддверии старта курса «Python Developer. Basic» и 🔥 получите скидку на обучение: https://clck.ru/3FjvdB
Реклама. ООО «Отус онлайн-образование», ОГРН 1177746618576
⚙️ uuid.uuid4()
Метод uuid.uuid4()
из модуля uuid
генерирует случайный UUID (универсально уникальный идентификатор), основанный на случайных данных. Это полезно для создания уникальных идентификаторов для объектов.
Python Learning 👩💻
⚙️ os.getpid()
Метод os.getpid()
возвращает идентификатор текущего процесса. Это полезно для отладки и мониторинга выполнения программ.
Python Learning 👩💻
❓ Вопрос на собеседовании
Что такое метаклассы в Python, как они работают, и зачем их использовать?
Ответ ⬇️
Метакласс в Python — это класс, который управляет созданием других классов. Обычно метаклассы используются, если нужно модифицировать или дополнить поведение классов во время их создания. Метакласс контролирует процесс создания класса и может добавлять новые методы, изменять существующие атрибуты или проверять корректность структуры класса.
Метаклассы задаются через ключевое слово metaclass в определении класса. Например, можно создать метакласс, чтобы автоматически добавлять новые методы или атрибуты.
Пример использования ⚙️
# Создаем метакласс
class MyMeta(type):
def __new__(cls, name, bases, dct):
dct['greet'] = lambda self: f"Hello from {name}!"
return super().__new__(cls, name, bases, dct)
# Используем метакласс
class MyClass(metaclass=MyMeta):
pass
obj = MyClass()
print(obj.greet()) # Вывод: Hello from MyClass!
⚙️ weakref.WeakValueDictionary()weakref.WeakValueDictionary
из модуля weakref
создаёт словарь, где значения являются слабой ссылкой на объекты. Это полезно для кэширования данных, которые должны автоматически удаляться, когда больше нет других ссылок на объект.
Python Learning 👩💻
❓ Вопрос на собеседовании
Что такое метаклассы в Python, как они работают, и зачем их использовать?
Ответ ⬇️
Метакласс в Python — это класс, который управляет созданием других классов. Обычно метаклассы используются, если нужно модифицировать или дополнить поведение классов во время их создания. Метакласс контролирует процесс создания класса и может добавлять новые методы, изменять существующие атрибуты или проверять корректность структуры класса.
Метаклассы задаются через ключевое слово metaclass в определении класса. Например, можно создать метакласс, чтобы автоматически добавлять новые методы или атрибуты.
Пример использования ⚙️
# Создаем метакласс
class MyMeta(type):
def __new__(cls, name, bases, dct):
dct['greet'] = lambda self: f"Hello from {name}!"
return super().__new__(cls, name, bases, dct)
# Используем метакласс
class MyClass(metaclass=MyMeta):
pass
obj = MyClass()
print(obj.greet()) # Вывод: Hello from MyClass!
⚙️ inspect.getclosurevars()
Метод inspect.getclosurevars()
из модуля inspect
позволяет извлечь значения замыканий из функции. Это полезно для анализа внутреннего состояния функций с замыканиями.
Python Learning 👩💻
⌛ Что будет выведено при выполнении кода?
Пояснение ⬇️
Метод @property превращает radius в геттер, а метод @radius.setter добавляет проверку значения. Сначала radius возвращает 5, затем успешно устанавливается в 10. Код выполняется корректно.
Учишь Python, но как дело доходит до собственного кода — всё, кирдык? 😥
На форумах только одно: «Больше практиковаться!» А толку? Ноль понимания и никакой поддержки от профи…
Плавали - знаем)) Поэтому специально для тебя - чат для Python-щиков 🤝
Что получишь?
1️⃣ Сможешь задавать любые вопросы без страха и осуждения и получать ответы за минуты, а не часы поиска в инете
2️⃣ Регулярные плюшки в виде стримов от препода с 15-ти летним опытом
3️⃣ Общение с единомышленниками и заряд мотивации
➡️ А еще, забирай в закрепе БЕСПЛАТНЫЙ вводный курс по Python
Короче, всё для прокачки! Залетай к нам — ссылка на чат (тык)
🚫 Антипаттерн недели: Неоптимальная фильтрация данных через циклы
Использование обычных циклов для фильтрации данных в списках или других коллекциях может быть неэффективным и затрудняет читаемость кода. Это особенно актуально, когда в Python уже есть встроенные средства для таких задач.
✔️ Используйте встроенные функции, такие как filter()
или list comprehension
, чтобы сделать код более читаемым и производительным.
Python Learning 👩💻
Любимые подписчики, поздравляю вас с наступающим новым годом! Пусть в 2025 году исполнятся все ваши самые заветные желания🎄🎄🎄🎄
Читать полностью…⚙️ tempfile.NamedTemporaryFile()
Метод tempfile.NamedTemporaryFile()
из модуля tempfile
создаёт временный файл, который автоматически удаляется при закрытии. Это удобно для временного хранения данных.
Python Learning 👩💻
#Вопросы_с_собеседования
Как проверить файл .py на синтаксические ошибки, не запуская его?
Утилита py_compile, позволит проверить файл .py на наличие синтаксических ошибок без его запуска.
Используется py_compile очевидно:
1. открываем командную строку/терминал.
2. переходим в каталог, содержащий файл .py, который вы хотите проверить
3. выполняем: python -m py_compile yourfile.py где yourfile.py - это имя файла, который вы хотите проверить.
Эта команда выполнит проверку файла и выведет описание любых синтаксических ошибок, которые были найдены, или пустой вывод, если ошибок нет.
Когда это может быть полезно? Например, если код большой и в процессе задействует много ресурсов, а нужно всего лишь удостовериться в его валидности.
Python Learning 👩💻
⌛ Что будет выведено при выполнении кода?
Пояснение ⬇️
*args собирает все позиционные аргументы в кортеж (1, 2, 3), а **kwargs собирает именованные аргументы в словарь {'a': 4, 'b': 5}. Код корректен и выводит оба объекта в соответствующем формате.
⚙️ secrets.token_hex()
Метод secrets.token_hex()
используется для генерации безопасных случайных токенов. Это полезно для создания уникальных идентификаторов, паролей или API-ключей.
Python Learning 👩💻
⚙️ pathlib.Path.exists()
Метод pathlib.Path.exists()
используется для проверки существования файла или директории. Это удобный способ работы с файловой системой в Python.
Python Learning 👩💻
LeetCode теперь в Telegram!
LeetCode — это сайт, который позволяет быстро готовиться к техническим собеседованиям по программированию. Там публикуются задачи с собеседований в Google и Microsoft с решениями.
Подписывайтесь: @leetcode
⚙️ traceback.format_exc()
Метод traceback.format_exc()
из модуля traceback
используется для получения форматированной строки трассировки исключения. Это полезно для логирования ошибок или их анализа.
Python Learning 👩💻
Друзья, на связи ваш админ.
Я тут сделал бота для знакомств @tinder. Буду рад, если вы оцените и воспользуетесь. Если буду какие-то замечания, пишите, буду благодарен)
❓ Вопрос на собеседовании
Как работает __getattr__
и __getattribute__
в Python, и в чём между ними разница?
Ответ ⬇️
__getattr__ и __getattribute__ — это специальные методы для управления доступом к атрибутам объекта.
__getattribute__ вызывается для любого обращения к атрибуту объекта.
__getattr__ вызывается только в случае, если атрибут не найден стандартным способом.
Разница: __getattribute__ перехватывает все обращения, а __getattr__ только пропущенные. Это делает __getattr__ безопаснее для использования, так как он не нарушает стандартный процесс получения атрибутов.
Пример использования ⚙️
class MyClass:
def __getattr__(self, name):
return f"Атрибут {name} отсутствует!"
def __getattribute__(self, name):
if name == "special":
return "Это особый атрибут"
return super().__getattribute__(name)
obj = MyClass()
print(obj.special) # Это особый атрибут
print(obj.undefined) # Атрибут undefined отсутствует!
⚡️ В сети начали массово сливать курсы и книги известных онлайн школ
Вот отсортированная база с тонной материала(постепенно пополняется):
БАЗА (4687 видео/книг):
(363 видео, 87 книги) — Python
(415 видео, 68 книги) — Frontend
(143 видео, 33 книги) — ИБ/Хакинг
(352 видео, 89 книги) — С/С++
(343 видео, 87 книги) — Java
(176 видео, 32 книги) — Git
(293 видео, 63 книги) — C#
(174 видео, 91 книги) — DevOps
(167 видео, 53 книги) — PHP
(227 видео, 83 книги) — SQL/БД
(163 видео, 29 книги) — Linux
(107 видео, 43 книги) — СисАналз
(181 видео, 32 книги) — Go
(167 видео, 43 книги) — Kotlin/Swift
(112 видео, 24 книги) — Flutter
(137 видео, 93 книги) — DS/ML
(113 видео, 82 книги) — GameDev
(183 видео, 37 книги) — UI/UX
(129 видео, 73 книги) — QA
(213 видео, 63 книги) — Rust
(121 видео, 24 книги) — Ruby
Скачивать ничего не нужно — все выложили в Telegram
⚙️ asyncio.gather()
Метод asyncio.gather()
из модуля asyncio
позволяет запускать несколько асинхронных задач одновременно и ожидать их завершения. Это удобный инструмент для работы с конкурентным выполнением задач.
Python Learning 👩💻
⚙️ sys.getrefcount()
Метод sys.getrefcount()
позволяет получить количество ссылок на объект. Это полезно для анализа работы сборщика мусора и управления памятью в Python.
Python Learning 👩💻
⌛ Что будет выведено при выполнении кода?
Пояснение ⬇️
Аргумент message имеет значение по умолчанию "Hello". При вызове greet("Alice") используется значение по умолчанию, результат: Hello, Alice!. Во втором вызове передаётся ключевой аргумент message="Hi", поэтому результат: Hi, Bob!. Код выполняется корректно.
🚫 Антипаттерн недели: Использование вложенных циклов для обработки больших данных
Вложенные циклы при обработке больших объёмов данных значительно снижают производительность, особенно если внутри вложенного цикла выполняются сложные операции. Это приводит к избыточному времени выполнения программы.
✔️ Используйте встроенные функции и методы, такие как zip
, enumerate
или библиотеку numpy
, чтобы сократить количество циклов.
Python Learning 👩💻
⚙️ abc.ABCMeta
Класс abc.ABCMeta
из модуля abc
используется для создания абстрактных базовых классов (Abstract Base Classes). Это позволяет определить методы, которые должны быть реализованы в подклассах, и предотвращает создание экземпляров базового класса.
Python Learning 👩💻
🤔 Как это работает? — Рекурсия на примере факториала
Рекурсия — это техника, при которой функция вызывает саму себя. Функция факториала — классический пример использования рекурсии. Давайте разберём, как это работает.
➡️ Как это работает:•
Если n == 0
, функция возвращает 1 (базовый случай).•
В остальных случаях функция вызывает саму себя с аргументом n - 1
.•
Результаты этих вызовов умножаются на текущее значение n
.
Развернутый аналог:
def factorial_iterative(n):
result = 1
for i in range(1, n + 1):
result *= i
return result
⚡️Слита База из 1000+ топовых IT-курсов
👩💻 Все языки: @main_it_baza
🖥 Python: @python_baza
👩💻 Frontend: @frontend_baza
👩💻 Backend: @backend_baza
🎨 Дизайн: @design_baza
📊 Архив: @archive_baza
Всё лучшее про IT бесплатно — уже на Базе 🚀