Technical Flashcards
В чем разница между списком и кортежем?
1) Список можно изменить после создания.
2) Кортеж нельзя изменить после создания.
3) Список упорядочен. Он представляет собой упорядоченные последовательности объектов, как правило, одного и того же типа. Например, все имена пользователей упорядочены по дате создания: [«Seth», «Ema», «Eli»].
4) У кортежа есть структура. В каждом индексе могут сосуществовать различные типы данных. Например, такая запись базы данных в памяти: (2, «Ema», «2020–04–16») # id, name, created_at.
Как выполняется интерполяция строк?
интерполяция - подстановка
name = ‘Chris’
- f strings
print(f’Hello {name}’) - % operator
print(‘Hey %s %s’ % (name, name)) - format
print(
“My name is {}”.format((name))
)
В чем разница между “is” и “==”?
is проверяет идентичность (ссылается на тот же объект), а == проверяет равенство (одинаковость).
Что такое декоратор?
Декоратор позволяет добавить новую функциональность к существующей функции. Например, замеряет время работы функции или выводит логи
Объясните функцию range
Range генерирует список целых чисел. Ее можно использовать тремя способами.
range(stop): генерирует целые числа от 0 до целого числа stop:
range(start, stop): генерирует целые числа от start до stop
range(start, stop, step): генерирует целые числа от start до stop с интервалами step:
Определите класс car с двумя атрибутами: color и speed. Затем создайте экземпляр и верните speed
class Car :
def __init__(self, color, speed):
self.color = color
self.speed = speed
car = Car(‘red’,’100mph’)
car.speed
#=> ‘100mph’
В чем разница между методами экземпляра, класса и статическими методами в Python?
Методы экземпляра: принимают параметр self и относятся к определенному экземпляру класса.
Статические методы: используют декоратор @staticmethod, не связаны с конкретным экземпляром и являются автономными (атрибуты класса или экземпляра не изменяются).
Методы класса: принимают параметр cls, можно изменить сам класс.
В чем разница между func и func()?
func — это представляющий функцию объект, который можно назначить переменной или передать другой функции.
Функция func() с круглыми скобками вызывает функцию и возвращает результат.
Объясните, как работает функция map
Она возвращает объект (итератор), который перебирает значения, применяя функцию к каждому элементу.
def add_three(x):
return x + 3
li = [1,2,3]
list(map(add_three, li))
#=> [4, 5, 6]
Объясните, как работает функция reduce
reduce принимает функцию и последовательность — и проходит по этой последовательности. На каждой итерации в функцию передаются как текущий элемент, так и выходные данные предыдущего элемента. В конце концов, возвращается одно значение:
Объясните, как работает функция filter
Каждый элемент начальной последовательности передается функции, которая включает его в последовательность, если по условию получает True, и отбрасывает в случае False
Переменные в Python передаются по ссылке или по значению?
все имена передаются по ссылке, но в некоторых ячейках памяти хранятся объекты, а в других — указатели на другие ячейки памяти.
Как развернуть список?
.reverse() вызывается в списке и изменяет его
Как работает умножение строк?
Посмотрим результат умножения строки ‘cat’ на 3:
‘cat’ * 3
#=> ‘catcatcat’
В результате содержимое строки повторяется трижды.
Как работает умножение списка?
Посмотрим на результат умножения списка [1,2,3] на 2:
[1,2,3] * 2
#=> [1, 2, 3, 1, 2, 3]
Содержание списка [1,2,3] повторяется дважды.
Что означает self в классе?
Self ссылается на экземпляр класса. Так метод может обновлять объект, к которому принадлежит.
Ниже передача self в __init__() дает возможность установить цвет экземпляра при инициализации:
class Shirt:
def __init__(self, color):
self.color = color
s = Shirt(‘yellow’)
s.color
#=> ‘yellow’
Как объединить списки в Python?
Списки объединяются при сложении. Обратите внимание, что с массивами так не получается:
В чем разница между глубокой и мелкой копиями?
Для неизменяемых объектов глубокое и мелкое (поверхностное) копирование обычно не отличаются.
Мелкая копия создает новый объект, но заполняет его ссылками на оригинал.
copy.deepcopy(). Оригинал и копия полностью независимы, а изменения в одном не оказывают никакого влияния на другой:
В чем разница между списками и массивами?
Примечание: в стандартной библиотеке Python есть объект array, но здесь мы специально обсуждаем массив из популярной библиотеки Numpy.
Списки в каждом индексе можно заполнять разными типами данных. Массивы требуют однородных элементов.
Арифметические действия в списках добавляют или удаляют элементы из списка. Арифметические действия на массивах соответствуют функциям линейной алгебры.
Массивы используют меньше памяти и обладают значительно большей функциональностью.
Как объединить два массива?
Помните, что массивы — это не списки. Это библиотека Numpy и здесь работает линейная алгебра.
Для объединения массивов нужно использовать соответствующую функцию Numpy .concatenate:
import numpy as np
a = np.array([1,2,3])
b = np.array([4,5,6])
np.concatenate((a,b))
#=> array([1, 2, 3, 4, 5, 6])
Что вам нравится в Python?
Python очень удобочитаем, и есть так называемый «питоновский способ» решения почти любой задачи, то есть самый понятный, ясный и лаконичный код.
Какая ваша любимая библиотека в Python?
с точки зрения статистики pandas - использовалась во всех проектах, эмоционально - sklearn. Обожаю точные прогнозы
Назовите изменяемые и неизменяемые объекты
Неизменяемость означает, что состояние нельзя изменить после создания. Примеры: int, float, bool, string и tuple.
Состояние изменяемых объектов можно изменить. Примеры: list, dict и set.
Как округлить число до трех десятичных знаков?
Используйте функцию round(value, decimal_places):
Как разбить список?
Срез list[start:stop:step]
Что такое pickle?
это модуль сериализации и десериализации объектов в Python.
“Pickling” - процесс преобразования объекта Python в поток байтов, а “unpickling” - обратная операция, в результате которой поток байтов преобразуется обратно в Python-объект.
Какая разница между словарями и JSON?
Dict (словарь) — это тип данных Python, представляющий собой набор индексированных, но неупорядоченных пар ключ-значение.
JSON — просто строка, которая следует заданному формату и предназначена для передачи данных.
Какие ORM вы использовали в Python?
Технология ORM (object-relational mapping, объектно-реляционное отображение) связывает модели данных (обычно в приложении) с таблицами БД и упрощает транзакции с базой данных.
В контексте Flask обычно используется SQLAlchemy, а у Django собственная ORM.
Как работают any() и all()?
Any возвращает true, если хоть один элемент в последовательности соответствует условию, то есть является true.
All возвращает true только в том случае, если условию соответствуют все элементы в последовательности.
Где быстрее поиск: в словарях или списках?
Поиск значения в списке занимает O(n) времени, потому что нужно пройти весь список.
Поиск ключа в словаре занимает O(1) времени, потому что это хэш-таблица.
Разница во времени может быть огромной, если значений много, поэтому для производительности обычно рекомендуют словари. Но у них есть другие ограничения, такие как необходимость уникальных ключей.
В чем разница между модулем и пакетом?
Модуль — это файл или набор файлов, которые импортируются вместе:
import sklearn
Пакет — это каталог с модулями:
from sklearn import cross_validation
Таким образом, пакеты — это модули, но не все модули являются пакетами.
Как увеличить и уменьшить целое число в Python?
Инкремент и декремент можно сделать с помощью += и -=:
Как вернуть двоичный код целого числа?
Используйте функцию bin():
Как удалить из списка дубликаты?
Это можно сделать путем преобразования списка в набор, а затем обратно в список:
a = [1,1,1,2,3]
a = list(set(a))
print(a)
#=> [1, 2, 3]
Обратите внимание, что наборы не обязательно поддерживают порядок следования списка.
Как проверить, существует ли значение в списке?
Используйте in:
‘a’ in [‘a’,’b’,’c’]
#=> True
‘a’ in [1,2,3]
#=> False
В чем разница между append и extend?
append добавляет значения в список, а extend добавляет в список значения из другого списка:
Как получить абсолютное значение целого числа?
Это можно сделать с помощью функции abs()
Как объединить два списка в список кортежей?
Для объединения в список кортежей можно использовать функцию zip, причем не только двух, но трех и более списков.
a = [‘a’,’b’,’c’]
b = [1,2,3]
[(k,v) for k,v in zip(a,b)]
#=> [(‘a’, 1), (‘b’, 2), (‘c’, 3)]
Как отсортировать словарь по ключам, в алфавитном порядке?
Нельзя «отсортировать» словарь, поскольку словари не поддерживают упорядочение, но можно вернуть отсортированный список кортежей с ключами и значениями из словаря:
d = {‘c’:3, ‘d’:4, ‘b’:2, ‘a’:1}
sorted(d.items())
#=> [(‘a’, 1), (‘b’, 2), (‘c’, 3), (‘d’, 4)]
Как реализуется наследование классов в Python?
В приведенном ниже примере класс Audi является наследником Car. И вместе с этим наследуются методы экземпляра родительского класса:
class Car():
def drive(self):
print(‘vroom’)
class Audi(Car):
pass
audi = Audi()
audi.drive()
Как удалить все пробелы из строки?
Можно разделить строку в местах пробелов, а затем снова соединить без пробелов:
s = ‘A string with white space’
’‘.join(s.split())
#=> ‘Astringwithwhitespace’
Двое читателей рекомендовали более каноничный способ замены
s = ‘A string with white space’
s.replace(‘ ‘, ‘’)
#=> ‘Astringwithwhitespace’
Почему мы используем enumerate() при итерации последовательности?
enumerate() позволяет отслеживать индекс при итерации последовательности. Это более нативный способ, чем определение и приращение целого числа, представляющего индекс
В чем разница между pass, continue и break?
Заглушка pass означает «ничего не делать». Обычно мы используем эту функцию, потому что Python не позволяет создавать класс, функцию или оператор if без кода внутри.
continue отправляет вас к следующему элементу в цикле, останавливая выполнение для текущего элемента.
break прерывает цикл, и последовательность больше не повторяется.
Преобразуйте следующий цикл for в генератор списков (list comprehension)
a = [1,2,3,4,5]
a2 = []
for i in a:
a2.append(i + 1)
print(a2)
#=> [2, 3, 4, 5, 6]
a3 = [i+1 for i in a]
print(a3)
#=> [2, 3, 4, 5, 6]
Генератор списка обычно считается более каноническим способом в Python, если он остается понятным.
Приведите пример тернарного оператора
Тернарный (условный) оператор — это однострочный оператор if/else.
x = 5
y = 10
‘greater’ if x > 6 else ‘less’
#=> ‘less’
‘greater’ if y > 6 else ‘less’
#=> ‘greater’
Проверьте, что в строке только числа
Можно использовать isnumeric():
‘123a’.isnumeric()
#=> False
‘123’.isnumeric()
#=> True
Проверьте, что в строке только буквы
Можно использовать isalpha():
‘123a’.isalpha()
#=> False
‘a’.isalpha()
#=> True
Проверьте, что в строке только буквы и цифры
Здесь можно использовать isalnum():
‘123abc…‘.isalnum()
#=> False
‘123abc’.isalnum()
#=> True
Получите список ключей из словаря
Это можно сделать через передачу словаря в конструктор list():
d = {‘id’:7, ‘name’:’Shiba’, ‘color’:’brown’, ‘speed’:’very slow’}
list(d)
#=> [‘id’, ‘name’, ‘color’, ‘speed’]
Как перевести строку в верхний/нижний регистр?
Можно использовать строковые методы upper() и lower():
small_word = ‘potatocake’
big_word = ‘FISHCAKE’
small_word.upper()
#=> ‘POTATOCAKE’
big_word.lower()
#=> ‘fishcake’
В чем разница между remove, del и pop?
remove() удаляет первое совпадающее значение
del удаляет элемент по его индексу
pop() удаляет элемент по индексу и возвращает этот элемент:
Приведите пример генератора словарей (dict comprehension)
Ниже мы создадим словарь с буквами алфавита в качестве ключей и индексами в качестве значений:
создаем список букв
import string
list(string.ascii_lowercase)
alphabet = list(string.ascii_lowercase)
генерация словаря
d = {val:idx for idx,val in enumerate(alphabet)}
d
#=> {‘a’: 0,
#=> ‘b’: 1,
#=> ‘c’: 2,
#=> …
#=> ‘x’: 23,
#=> ‘y’: 24,
#=> ‘z’: 25}
Как выполняется обработка исключений в Python?
Для обработки исключений Python предоставляет конструкцию из трех слов: try, except и finally.