Solution Review: Time My Functions
The solution to the 'Time My Functions' challenge.
We'll cover the following
import time# Decorator for timing the passed functionsdef time_taken(func):def wrapper(*args, **kwargs):start = time.time()resp = func(*args, **kwargs)end = time.time()return (end - start)return wrapper# Class decorator making use of time_taken decorator to debug class methodsdef timeit(cls):for key, val in vars(cls).items():if callable(val):setattr(cls, key, time_taken(val))return cls''' Metaclass feeding created class object to timeit method to get timingfunctionality enabled objects '''class TimeMeta(type):def __new__(cls, clsname, bases, clsdict):obj = super().__new__(cls, clsname, bases, clsdict)obj = timeit(obj)return obj''' Base class with metaclass TimeMeta, now all the subclass of thiswill have timing applied '''class Animal(metaclass=TimeMeta):def talk(self):time.sleep(1)print("Animal talk")class Cow(Animal):def talk(self):time.sleep(1)print("Moo")class Dog(Animal):def talk(self):time.sleep(1)print("Bark")animal = Animal()cow = Cow()dog = Dog()print(animal.talk())print(cow.talk())print(dog.talk())
Get hands-on with 1300+ tech skills courses.