Python:Рецепты/Простое профилирование программы

Материал из Онлайн справочника
Перейти к: навигация, поиск

Проверка/Оформление/Редактирование: Мякишев Е.А.


Простое профилирование программы

Задача

Измерение периодов времени, в течение которых выполняются определенные фрагменты кода.

Pixel Art Mini Meow Animated.gif Это простой способ профилирования, если вам нужна более информативная детализация, обратитесь к функции cProfile.run()


Решение

Вызовите функцию time.time() в начале блока кода, время выполнения которого вы хотите измерить, а затем в конце этого блока, затем вычтите значение первой временной метки из значения второй, в результате получите длительность промежутка времени, прошедшего между двумя вызовами.

Пример

Измерим сколько займет времени вычисление произведения первых 100 000 чисел.

Код

  1. import time
  2. startTime = time.time()
  3. # Вычисление произведения первых 100 000 чисел
  4. product = 1
  5. for i in range(1, 100000):
  6.     product = product * i
  7. endTime = time.time()
  8. print('Длина результата: %s цифр.' % (len(str(product))))
  9. print('Расчет занял %s секунд' % (endTime - startTime))

См.также

Внешние ссылки