x * x for x in range(10)
вычисляет квадрат числа x для каждого четного числа x в диапазоне от 0 до 9 (то есть 0, 2, 4, 6, 8
).Фигурные скобки и
x:
обозначают генерацию словаря, где в качестве ключа будет выступать исходный четный x (то есть числа 0, 2, 4, 6, 8
).Ключи словаря тоже не упорядочиваются, потому в разных версиях интерпретаторов мы будем получать разный порядок ключей.
На каждой итерации внутреннего цикла вам доступен элемент
Результат каждого сложения добавляется в множество
x
из первого списка и элемент y
из второго списка, и вы выполняете сложение этих двух значений: x + y
.Результат каждого сложения добавляется в множество
a
. Множество автоматически удаляет дубликаты.Какой встроенный модуль позволяет замерить время исполнения кода?
Anonymous Quiz
9%
statistics
23%
datetime
59%
time
9%
Никакой из вышеперечисленных
Модуль time позволяет замерить время исполнения кода. Вот пример функции с ее использованием:
Что делают остальные модули, можно посмотреть в полном списке в документации Python.
import time
def timer(func, *args): # Упрощенная функция измерения времени
start = time.clock()
for i in range(1000):
func(*args)
return time.clock() - start # Суммарное истекшее время в секундах
Что делают остальные модули, можно посмотреть в полном списке в документации Python.
map() — самый быстрый вариант, поскольку функция фактически работает на C. И это превышает скорости конкурентов. А кто в рейтинге взял серебро и бронзу?
Как видно, в каждой функции по 10 миллионов шагов функций — каждая строит список из 10 000 элементов 1000 раз.
Запустив сценарий в Python 3.7, мы получаем следующие результаты — map() быстрее списковых включений, они оба быстрее циклов for, а генераторные выражения и функции находятся посередине (время в секундах):
Генераторное выражение должно делать дополнительную работу по сохранению и
восстановлению своего состояния во время выпуска значений.
Как видно, в каждой функции по 10 миллионов шагов функций — каждая строит список из 10 000 элементов 1000 раз.
Запустив сценарий в Python 3.7, мы получаем следующие результаты — map() быстрее списковых включений, они оба быстрее циклов for, а генераторные выражения и функции находятся посередине (время в секундах):
forLoop :: 2.34160
listComp : 1.31783
mapCall :: 0.41968
genExpr :: 1.92063
genFunc :: 1.93672
Генераторное выражение должно делать дополнительную работу по сохранению и
восстановлению своего состояния во время выпуска значений.
Какой метод позволяет узнать количество строк датафрейма?
Anonymous Quiz
34%
df.shape
47%
df.size
3%
df.dtypes
16%
Никакой из вышеперечисленных
Модуль timeit позволяет измерить время исполнения кода.
В команде
Вывод у команды будет такой (проверено на Python 3.13.1):
В команде
python3 -m timeit -n 1000 -r 3 "L = [1,2,3,4,5]" "M = [x + 1 for x in L]"
используются несколько флагов, которые управляют поведением модуля:-n 1000
: флаг указывает количество повторений. Тестируемый код будет выполняться 1000 раз за каждую итерацию.-r 3
: флаг задает количество повторных запусков всего тестаВывод у команды будет такой (проверено на Python 3.13.1):
1000 loops, best of 3: 111 nsec per loop
Из всех флагов только -s действительный:
Для указания кода настройки в режиме командной строки применяется строка после флага
время только итерации:
Подробнее в документации
-s S, --setup=S
statement to be executed once initially (default pass)
Для указания кода настройки в режиме командной строки применяется строка после флага
—s
(или несколько в случае многострочного кода настройки), а в режиме вызовов API-интерфейса — аргумент setup. В итоге тесты можно ориентировать более четко, например, выносить инициализацию списка выносится в код, чтобы измерятьвремя только итерации:
python3 -m timeit -n 1000 -r 3 -s "L = [1,2,3,4,5]" "M = [x + 1 for x in L]"
Подробнее в документации
Python documentation
timeit — Measure execution time of small code snippets
Source code: Lib/timeit.py This module provides a simple way to time small bits of Python code. It has both a Command-Line Interface as well as a callable one. It avoids a number of common traps fo...
Что выведет код?
Anonymous Quiz
15%
['spam','spam','spam']
15%
['spamspamspam']
66%
['s', 'p', 'a', 'm', 's', 'p', 'a', 'm', 's', 'p', 'a', 'm']
5%
Error
—
— используется генератор списка
— Функция
'spam' * 3
генерирует строку 'spamspamspam'
, которая состоит из трех повторений строки 'spam'
;— используется генератор списка
[]
, который обходит каждый символ строки 'spamspamspam'
;— Функция
f(x)
просто возвращает переданное ей значение x без изменений.