El conjunto de pruebas no intenta utilizar lo importado, timeit
por lo que es difícil saber cuál fue la intención. Sin embargo, esta es una respuesta canónica, por lo que un ejemplo completo timeit
parece estar en orden, elaborando la respuesta de Martijn .
Los documentostimeit
ofrecen muchos ejemplos y banderas que vale la pena ver. El uso básico en la línea de comando es:
$ python -mtimeit "all(True for _ in range(1000))"
2000 loops, best of 5: 161 usec per loop
$ python -mtimeit "all([True for _ in range(1000)])"
2000 loops, best of 5: 116 usec per loop
Ejecute con -h
para ver todas las opciones. Python MOTW tiene una gran sección timeit
que muestra cómo ejecutar módulos a través de cadenas de código de importación y multilínea desde la línea de comandos.
En forma de script, normalmente lo uso así:
import argparse
import copy
import dis
import inspect
import random
import sys
import timeit
def test_slice(L):
L[:]
def test_copy(L):
L.copy()
def test_deepcopy(L):
copy.deepcopy(L)
if __name__ == "__main__":
parser = argparse.ArgumentParser()
parser.add_argument("--n", type=int, default=10 ** 5)
parser.add_argument("--trials", type=int, default=100)
parser.add_argument("--dis", action="store_true")
args = parser.parse_args()
n = args.n
trials = args.trials
namespace = dict(L = random.sample(range(n), k=n))
funcs_to_test = [x for x in locals().values()
if callable(x) and x.__module__ == __name__]
print(f"{'-' * 30}\nn = {n}, {trials} trials\n{'-' * 30}\n")
for func in funcs_to_test:
fname = func.__name__
fargs = ", ".join(inspect.signature(func).parameters)
stmt = f"{fname}({fargs})"
setup = f"from __main__ import {fname}"
time = timeit.timeit(stmt, setup, number=trials, globals=namespace)
print(inspect.getsource(globals().get(fname)))
if args.dis:
dis.dis(globals().get(fname))
print(f"time (s) => {time}\n{'-' * 30}\n")
Puede colocar fácilmente las funciones y argumentos que necesita. Tenga precaución cuando use funciones impuras y cuide el estado.
Salida de muestra:
$ python benchmark.py --n 10000
------------------------------
n = 10000, 100 trials
------------------------------
def test_slice(L):
L[:]
time (s) => 0.015502399999999972
------------------------------
def test_copy(L):
L.copy()
time (s) => 0.01651419999999998
------------------------------
def test_deepcopy(L):
copy.deepcopy(L)
time (s) => 2.136012
------------------------------
timeit
? Supongo que no. En ese caso, probablemente debería eliminar "with Pythons timeit" del título.