Decorators to indent-log function calls with parameter and timing
Project description
Decorators to log function calls with parameter and timing
Usage
Decorators to track down function call with indent. Both logging function and indent characters are configurable
Decorate a function:
from indented_logs import log_call
@log_call()
def method1(arg1, arg2):
return arg1 + arg2
method1(3, 4)
Output:
...CALL: method1(3, 4)
...'method1' RETURN: 7
...'method1' FINISHED in 0.000003 secs
Multiple functions:
from indented_logs import log_call
@log_call()
def get_data():
get_parameters()
query_db(conn="sample_conn_str")
@log_call()
def get_parameters():
pass
@log_call()
def query_db(conn):
return covert_data("1", "2")
@log_call()
def covert_data(a, b):
return (int(a), int(b))
get_data()
Output:
...CALL: get_data()
......CALL: get_parameters()
......get_parameters RETURN: None
......get_parameters FINISHED in 0.000004 secs
......CALL: query_db(, conn=sample_conn_str)
.........CALL: covert_data(1, 2)
.........covert_data RETURN: (1, 2)
.........covert_data FINISHED in 0.000005 secs
......query_db RETURN: (1, 2)
......query_db FINISHED in 0.000870 secs
...get_data RETURN: None
...get_data FINISHED in 0.002771 secs
Decorate class:
Using log_call_cls
from indented_logs import log_call_cls
@log_call_cls(indent="***", log_time=False, logger_func=log_with_capture)
class MyClass:
def method1(self, arg1, arg2):
self.method2(arg1)
def method2(self, arg1):
pass
obj = MyClass()
obj.method1("aaaaa", "bbbbbbb")
Ouput:
***CALL: method1(aaaaa, bbbbbbb)
******CALL: method2(aaaaa)
******method2 RETURN: None
******method2 FINISHED in 0.000005 secs
***method1 RETURN: None
***method1 FINISHED in 0.000916 secs
Customize indent characters:
from indented_logs import log_call
@log_call(indent='___')
def method1(arg1, arg2):
return arg1 + arg2
method1(3, 4)
Turn off logtime:
from indented_logs import log_call
@log_call(indent='___', log_time=False)
def method1(arg1, arg2):
return arg1 + arg2
method1(3, 4)
Output:
___CALL: method1(3, 4)
___'method1' RETURN: 7
___'method1' FINISHED in 0.000006 sec
Development
Conda environment
Create conda environment
conda env create -f environment.yml
If any dependency is added, remember to update conda environment file
conda env export --from-history > environment.yml
Tests
Run using pytest:
pytest -s --cov=src
Build and publish
Increase the version number in setup.py, run:
python -m build .
Publish to test Pypi:
python -m twine upload --repository testpypi dist/* --skip-existing
Publish to Pypi:
python -m twine upload --repository pypi dist/* --skip-existing
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file indented-logs-0.0.2.tar.gz
.
File metadata
- Download URL: indented-logs-0.0.2.tar.gz
- Upload date:
- Size: 4.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5b128161d9001a62daabdfb8b2b37bf9eeac2af64bb6c0132513c99c2eb2f765 |
|
MD5 | 007106c49e6c5873a76b1d03d56372a4 |
|
BLAKE2b-256 | 8c5d5f838d00b9af69f194b2e8138d37c12159e58430851c8907b204cde95237 |
File details
Details for the file indented_logs-0.0.2-py3-none-any.whl
.
File metadata
- Download URL: indented_logs-0.0.2-py3-none-any.whl
- Upload date:
- Size: 4.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8df41c4579f10e6a5e0a077533c5793d36d3eacc2afc2fde93a51bb5455e629c |
|
MD5 | d3e045fab112d386c1a69910a5dd78c9 |
|
BLAKE2b-256 | 4cf7bd5d6fe7b80efac48e7912dee991ea558d88b36e71683762776eb583e84f |