Timer Module with profiling features
Project description
Prerequisite:
Requires Python >= 3.10 as TimeProfiler makes use of new features from Python's typing module.
Timer Usage:
import time
from timer_module import TimerModule
timer_module = TimerModule().start()
timer_module.pause()
time.sleep(2)
timer_module.start()
time.sleep(2)
time_seconds = timer_module.get_time()
print(time_seconds)
set the timer
timer_module = TimerModule().set_time(5).start()
refresh time (keeps timer state)
timer_module.refresh()
reset time (resets everyting)
timer_module.reset()
Profiler Usage:
TimeProfiler also includes a "function_profiler" and "async_function_profiler", in a class the asynchronous methods are handled automatically, but for functions you need to select the appropriate decorator.
import time
from timer_module import TimeProfiler
# You only need this line to profile the entire class
# The program is run normally, this decorator will wrap
# The class and its methods in order to track execution time
@TimeProfiler().class_profiler
class ExampleClass:
def __init__(self):
time.sleep(0.1)
def method_1(self):
time.sleep(0.5)
self.method_2()
def method_2(self):
time.sleep(1)
self.method_3()
def method_3(self):
time.sleep(1)
self.method_4()
def method_4(self):
time.sleep(0.1)
self.method_5()
def method_5(self):
time.sleep(0.1)
ec = ExampleClass()
ec.method_1()
Output:
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
timer-module-1.0.2.tar.gz
(5.0 kB
view hashes)
Built Distribution
Close
Hashes for timer_module-1.0.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | ec865c78618948eabba4c6dfad37dd7ba76f573e241fc1a0a5532cd0a810b73d |
|
MD5 | 6b1e57190aad0a13586aa5c7a6f7e1d5 |
|
BLAKE2b-256 | 7bedd0c43e58cf4a510f7e7e89907e1c046e5e5a8c99a0c4986faa1841ed97e1 |