Подготовка к собеседованию на позицию Python-разработчика
Мы подготовили статью с темами и вопросами, которые работодатель может затронуть на собеседовании, и дополнили их небольшими объяснениями.
На сегодняшний день число Python-программистов продолжает расти, однако количество рабочих мест для них увеличивается не так быстро. Современному разработчику нужно быть конкурентоспособным, чтобы пробиться на желаемую позицию. Мы подготовили статью с темами и вопросами, которые работодатель может затронуть на собеседовании, и дополнили их небольшими объяснениями — по сути, это задачи по программированию на Python с решениями. Материал будет полезен продолжающим для повторения, а начинающим поможет сориентироваться, куда делать первые шаги, на что обратить внимание. Воспринимайте как своеобразный маяк.
Содержание статьи:
- Работа со списками.
- Отладка кода и тестирование.
- Массивы.
- Декораторы функций.
- Исключения.
- Итераторы.
- GIL.
- Передача аргументов.
- Вопросы вне определённых категорий.
- Дополнительно.
- Заключение.
Работа со списками
Лямбда-выражения, генераторы списков и выражения-генераторы
Лямбда-выражения — сокращённый метод создания однолинейных анонимных функций. Их простота часто (но не всегда) делает код более стройным и читабельным, чем классическое объявление функций. С другой стороны, та же простота ограничивает возможности и зоны применения лямбда-выражений.
Генераторы списков обеспечивают краткий синтаксис для создания списков. Они используются для составления списков, в которых каждый элемент — результат некоторой операции (операций) с элементами другой последовательности или итератором. Генераторы списков могут использоваться для создания подпоследовательности тех элементов, члены которых удовлетворяют определённому условию. Генераторы списков в Python — своеобразная альтернатива встроенным функциям map()
и filter()
.
Лямбда-выражения с функциями map()
и filter()
и генераторы списков схожи, поэтому выбор одного из этих инструментов субъективен и зависит от случая. Но следует отметить, что генераторы списков выполняются несколько быстрее — вызов лямбда-функции создаёт новый стековый кадр.
Выражения-генераторы синтаксически и функционально похожи на генераторы списков, но есть важные различия между их механизмами работы и областями применения. Итерация при наложении выражения-генератора или генератора списка будет делать всё то же самое, но генератор списков сначала создаст целый список в памяти, в то время как выражение-генератор будет создавать элементы на ходу по мере необходимости. Выражения-генераторы могут быть использованы в большом или даже бесконечном количестве последовательностей. А генерирование значений по требованию обеспечивает повышение производительности и снижение использования памяти. Однако следует отметить, что стандартные методы списков list
в Python могут применяться на результатах выполнения генератора, но не на самом генераторе.
В чём разница между списком и кортежем?
Основная разница: список может изменяться, а кортеж — нет. Работа с кортежами быстрее, чем со списками. Если необходимо определить постоянный набор значений, и все, что с ним когда-либо надо делать, — это перебирать его элементы, рациональнее использовать кортеж вместо списка. Кортеж также может выступать в качестве ключа для словарей, в отличие от списка.
Самые продвинутые кандидаты скажут, что кортежи неоднородны и их использование аналогично использованию struct
в языке программирования С. Списки же аналогичны привычным массивам.
Отладка кода и тестирование
Какой подход вы используете для модульного тестирования в Python?
Фундаментальный ответ на этот вопрос относится к использованию фреймворка Python — unittest.
Unittest поддерживает автоматизацию тестов, использование общего кода для настройки и завершения тестов, объединение тестов в группы, а также позволяет отделять тесты от фреймворка для формирования отчётов. Модуль unittest представляет классы, упрощающие поддержку этих качеств для набора тестов.
Вас могут попросить описать ключевые элементы структуры unittest, а именно:
- испытательный стенд (test fixture);
- тестовый случай (test case);
- набор тестов (test suite);
- исполнитель тестов (test runner).
Mock — недавнее дополнение к модулю unittest, которое позволяет заменять часть тестируемой системы mock-объектами. Mock теперь часть стандартной библиотеки Python, доступной как unittest.mock
в Python 3.3 и новее.
Как производится отладка программы на Python? Можно ли выполнить Python-код пошагово?
В Python есть встроенный модуль pdb, который определяет интерактивный отладчик для исходного кода программ Python.
Запуск pdb
из интерпретатора:
Из скриптового файла Python:
Массивы
Рассмотрите два подхода ниже для инициализации массива и массивов. В чём разница между этими подходами и почему вам следует использовать только один из них?
Кажется, что оба подхода обеспечивают один и тот же результат, но есть важное различие. Второй метод, как и ожидалось, создаёт массив из трёх элементов, каждый из которых является независимым четырехэлементным массивом. В первом же методе все члены массива указывают на один и тот же объект. Это может привести к наиболее вероятному непредвиденному и нежелательному поведению, как показано ниже.
Что такое NumPy? Почему лучше использовать массивы NumPy вместо списков Python?
NumPy — пакет Python для научных вычислений, который способен работать с большими объёмами данных. Он включает в себя мощный N-мерный объект массива и набор продвинутых функций.
Также есть определённые причины, согласно которым лучше использовать массивы NumPy:
- массивы NumPy более компактны, чем списки;
- запись и чтение выполняются быстрее;
- массивы более эффективны из-за увеличения функциональности списков.
Как можно создать массив NumPy в Python?
Существует два способа создания массивов NumPy:
Первый:
Второй:
Декораторы функций
Зачем использовать декораторы функций?
Декораторы — вызываемые объекты в Python, которые используются для изменения или расширения функции или класса. Прелесть декораторов в том, что один декоратор может быть применён к нескольким функциям (или классам). Например, во Flask используются декораторы как механизм добавления новых портов в веб-приложении. Примеры некоторых наиболее распространённых применений декораторов включают добавление синхронизации, принудительное введение типов, логирование, предусловия и постусловия для класса или функции.
Что такое @classmethod, @staticmethod, @property?
Декораторы @classmethod
, @staticmethod
и @property
используются для функций, определённых внутри классов. Они ведут себя так:
Создайте логируемый декоратор
Возможно, вам потребуется логировать то, что выполняет определённая функция. Как правило, логирование прописывается внутри функции (класса). Однако, иногда нужно отследить поведение самой функции внутри программы.
Посмотрите на небольшой декоратор, который можно использовать для записи названия любой функции и того, что она делает:
Этот небольшой скрипт содержит функцию log
, которая принимает функцию как единственный аргумент. Мы создаем объект логгер, а название лог-файла такое же, как и у функции. После этого функция log
будет записывать, как наша функция была вызвана и что она возвращает, если возвращает.
Исключения
Что такое исключения?
Исключительные ситуации, или исключения (exceptions) — это ошибки, обнаруженные при исполнении кода. Например, к чему приведет попытка чтения несуществующего файла? А вдруг файл был случайно удален, пока программа работала? Такие ситуации обрабатываются при помощи исключений.
Если же Python не может понять, как обойти сложившуюся ситуацию, то ему не остается ничего, кроме как сообщить о найденной ошибке.
Простейший пример исключения — деление на ноль:
В этом случае интерпретатор сообщил об исключении ZeroDivisionError
— делении на ноль.
Иерархия исключений. Какие системные исключения вам знакомы?
Исключение, которое вы не видите при выполнении кода — BaseException
— это базовое исключение, которое наследует остальные.
В иерархии исключений выделяют две основные группы:
- Системные исключения и ошибки.
- Пользовательские исключения.
К системным относятся:
SystemExit
— исключение, порождаемое функциейsys.exit
при выходе из программы;KeyboardInterrupt
— возникает при прерывании программы пользователем (обычно сочетанием клавиш Ctrl + C).GeneratorExit
— возникает при вызове методаclose
объектаgenerator
.
Больше о работе исключений вы можете узнать в официальном руководстве.
Итераторы
Что такое итератор?
Итератор — интерфейс, предоставляющий доступ к элементам коллекции (массива или контейнера) и навигацию по ним. В различных системах итераторы могут иметь разные общепринятые названия. В терминах систем управления базами данных итераторы называются курсорами. В простейшем случае итератором в низкоуровневых языках является указатель.
В чём разница между итератором и генератором?
Эти термины тесно связаны (любой генератор — это итератор), их довольно часто путают, что иногда приводит к недопониманию. Итератор — более общая концепция. Это объект, у которого определены два метода: __next__
и __iter__
. С другой стороны, генератор — это итератор. Но не наоборот. Генератор может получаться использованием ключевого слова yield
в теле функции.
GIL
Концепция GIL заключается в том, что в каждый момент времени только один поток может исполняться процессором. Это сделано для того, чтобы между потоками не было борьбы за отдельные переменные. Исполняемый поток получает доступ ко всему окружению. Такая особенность реализации потоков в Python значительно упрощает работу с потоками и дает определенную потокобезопасность (thread safety).
Передача аргументов
Как передаются неизменяемые объекты?
Неизменяемые объекты передаются «по значению». Такие объекты, как целые числа и строки, передаются в виде ссылок на объекты, а не в виде копий объектов.
Как передаются изменяемые объекты?
Изменяемые объекты передаются «по указателю». Такие объекты, как списки и словари, также передаются в виде ссылок на объекты, что очень похоже на то, как в языке C передаются указатели на массивы – изменяемые объекты допускают возможность непосредственного изменения внутри функции так же, как и массивы в языке C.
Пример:
В этом фрагменте в момент вызова функции f(b)
переменной a
присваивается объект 88
, но переменная a
существует только внутри вызванной функции. Изменение переменной a
внутри функции не оказывает влияния на окружение, откуда была вызвана функция, – просто в момент вызова создается совершенно новый объект a
.
Что будет выведено после второго вызова append() в коде ниже?
Когда значением по умолчанию для аргумента функции является выражение, оно вычисляется только один раз, а не всегда при вызове функции. Таким образом, после того как аргумент list
был инициализирован в пустой массив, последующие вызовы функции без аргументов продолжат использовать тот же самый массив, что был инициализирован изначально.
Как можно изменить применение метода append в предыдущем вопросе, чтобы избежать нежелательного поведения, описанного там?
Есть альтернативная реализация метода append
, которая решит проблему:
Вопросы вне определённых категорий
Как можно поменять местами значения двух переменных внутри строки в Python?
Рассмотрим простой пример:
Во многих других языках программирования при замене значений X
и Y
требуется выполнить что-то вроде этого:
Но в Python существует возможность сделать это с помощью одной строки кода следующим образом:
Что будет выведено последним оператором ниже?
В любом замыкании в Python переменные связываются по имени. Таким образом, в приведённой выше строке кода будет выведено следующее:
Но, вероятно, это не совсем то, что автор кода выше хотел бы видеть.
Выход из ситуации — создание отдельной функции или передача аргументов по их имени:
Для чего служит ключевое слово «self»?
Ключевое слово self
— переменная, которая относится к экземпляру объекта. Когда создаётся класс, явная ссылка на объект того же типа класса отсутствует. Поэтому, чтобы ссылаться на текущий класс или объект, в Python используется ключевое слово self
.
Для чего служит ключевое слово «yield»?
Ключевое слово yield
может обратить любую функцию в генератор. Оно работает подобно оператору return
, с той разницей, что ключевое слово будет возвращать объект-генератор. Также функция может совершать несколько вызовов ключевого слова yield
.
Что такое __init__.py? Как импортировать класс из другого каталога?
__init__.py
в основном используется для инициализации пакетов Python.
Файл __init__.py
в каталоге lstm_m
указывает интерпретатору Python, что этот каталог должен обрабатываться как пакет Python.
Как импортировать класс из другого каталога?
Обычно __init__.py
является пустым файлом. А если нам нужно использовать lstm.py
в файле run.py
, то его нужно импортировать следующим образом:
Кроме того, внутри папки модуля должен быть файл __init__.py
, предназначенный для импорта.
Какие встроенные типы существуют в Python?
Существуют изменяемые и неизменяемые встроенные типы Python.
Изменяемые:
- списки;
- множества;
- словари.
Неизменяемые:
- строки;
- кортежи;
- числа.
Следует помнить, что выше перечислены только основные типы. На самом деле их больше шести.
Что такое docstring в Python?
Строка документации в Python (docstring) — способ документирования функций, модулей и классов. Стандарты оформления — на официальном сайте.
Как можно конвертировать число в строку?
Для преобразования числа в строку, как правило, используют встроенную функцию str()
, хотя есть и другие способы, такие как "{0:d}".format(число)
и "%d"%число
. Если вы хотите преобразовать десятичное число в восьмеричное (oct — octal) или шестнадцатеричное (hex — hexadecimal), используйте встроенную функцию oct()
или hex()
соответственно.
В чём разница между Xrange и range?
Функция xrange()
возвращает объект xrange
, в то время как range()
возвращает список и использует то же количество памяти, независимо от размера функции.
Как увидеть методы или атрибуты объекта?
Команда dir(x)
возвращает отсортированный список имен атрибутов для любого переданного в нее объекта. Если ни один объект не указан, dir()
возвращает имена в текущей области видимости.
Дополнительно
Если вы владеете английским языком, то рекомендуем пройти онлайн-тесты и проверить свои знания перед собеседованием.
Подборки материалов для изучения Python от нас: сайты и книги, ещё книги, ещё сайты. Короткие ответы на популярные вопросы, а также несколько хитростей. Не забудьте порешать задачи: вот список ресурсов, где это можно сделать.
Заключение
Вопросы и советы, представленные в этой статье, могут быть очень ценными вспомогательными средствами для подготовки соискателей к собеседованиям. Мы надеемся, разработчики найдут их полезными для самостоятельного тестирования своих знаний перед встречей с работодателем. Но не следует забывать, что все представленные выше вопросы — один из нескольких инструментов отбора кандидатов на должность в составе определённой стратегии. Готовьтесь внимательно и тщательно. Удачи!
124К открытий125К показов