-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathclockdeco.py
43 lines (37 loc) · 1.07 KB
/
clockdeco.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import time
import functools
def clock(func):
@functools.wraps(func)
def clocked(*args,**kwargs):
t0 = time.time()
result = func(*args,**kwargs)
elapsed = time.time() - t0
name = func.__name__
# arg_lst = []
# if args:
# arg_lst.append(', '.join(repr(arg) for arg in args))
# if kwargs:
# pairs = ['%s=%r' %(k,w) for k,w in sorted(kwargs.items())]
# arg_lst.append(', '.join(pairs))
# arg_str = ', '.join(arg_lst)
print('[%0.8fs] %s' % (elapsed, name))
#print('[%0.8fs] %s(%s) -> %r ' % (elapsed, name))#, arg_str, result))
return result
return clocked
def clockArgs(func):
@functools.wraps(func)
def clocked(*args,**kwargs):
t0 = time.time()
result = func(*args,**kwargs)
elapsed = time.time() - t0
name = func.__name__
arg_lst = []
if args:
arg_lst.append(', '.join(repr(arg) for arg in args))
if kwargs:
pairs = ['%s=%r' %(k,w) for k,w in sorted(kwargs.items())]
arg_lst.append(', '.join(pairs))
arg_str = ', '.join(arg_lst)
print('[%0.8fs] %s(%s) -> %r ' % (elapsed, name, arg_str, result))
return result
return clocked