Simple logger for python. Easy configuration and Multiprocess supported.
Project description
SL4P : simplest logging for your python
sl4p is a logging library that makes it easy to introduce more production-focused logging into your python applications.
sl4p users need not know anything about the slightly complex built-in python logging, although sl4p uses built-in Python's logging internally.
Quite simply, you can start logging right in any code with the three lines below.
from sl4p import *
log = sl4p.getLogger(__file__)
log.info("Hello Sl4p logger !")
Then, a log file with the contents below will be created in the folder ./sl4p_logs
in the same location as your code.
INFO | 2023.03.22-17:19:13 - embedding.py ( 86) :: OPERATING TIMEZONE: +9:00
INFO | 2023.03.22-17:19:13 - embedding.py ( 87) :: Program @c8abb11e started. <<ex1.py>>
DEBUG | 2023.03.22-17:19:13 - embedding.py ( 88) :: @@-- argv[0] = C:\path\to\your\python\app.py
INFO | 2023.03.22-17:19:13 - ex1.py ( 4) :: Hello Sl4p logger !
INFO | 2023.03.22-17:19:13 - embedding.py ( 105) :: Program c8abb11e finished <<ex1.py>> ----- Elapsed 0.0010 s
Don't waste your time learning logging. Just enjoy this!
Main Features
Here are the main features that are very easy to use:
Basic
- Logging that can be used right away with little to no setup required (by default config)
- Colored console log: Warning, Error, and Exception are output in progressively more emphasized colors (Python 3.6+)
- ConfigFile: Single/multi-application logger settings by JSON files and python dictionary
- Auto purging: log files can be divided and recorded by specified time period or filesize, and old ones can be automatically deleted
- Snippet log: Logging to separate files for specific modules or subset of your Python program package
- Logging in multi-threaded/multi-process (internally, without IPC, with recording to a same file)
- Log of program context info: Timezone info, program execution path, total program run time, etc.
Utils & Advanced
- SimpleTimer: a stopwatch logging utility that supports start and multiple checks
@sl4p_time()
records the time taken for function execution (optional user tag)@sl4p_try
,@sl4p_try_exit
automatically log traceback using Try~Except statements- Profiling: record CPU and memory usage as a separate CSV file during program life
- ExceptionHook: Register your function to execute in the event of an abnormal program termination
Installation
The 'sl4p' package can be easily installed using pip.
$ pip install sl4p
Or download the appropriate .whl file for your Python version from the 'dist' folder on GitHub.
$ pip install sl4p-{pkg_ver}-{py_ver}-none-any.whl
Configuration (Single App)
Sl4p has key concepts of 'configuration' and 'logging'.
Configuration decides sl4p logger's behavior including logging level, message format, logfile savedir and so on.
You can use Python dictionary or .cfg Yaml file to configuring as you want.
The following table describes the available keys and their corresponding values (default values indicated with an asterisk):
# Configured example
{
"__configver__": "C4", # For .cfg Yaml file, you must specify __configver__
"LOG": {
"use_console_print": true,
"console_level": "WARNING",
"logging_level": "DEBUG",
"logging_format": "basic",
"logfile_savedir": "logs",
"logfile_name": "EXAMPLE_1",
}
}
Key | Description | Available value (*default) |
---|---|---|
use_console_print |
Whether to print log messages to the console. | Bool (*) True, False |
console_level |
The minimum level of logs to be printed in console. Logs below this level will not be printed. If not be assigned, follow the logging_level. |
(*) "DEBUG", "INFO", "WARNING", "ERROR", "CRITICAL" |
console_format |
The level of detail to include in the log message in console. If not be assigned, follow the logging_format. | "simple", (*) "basic", "detail", "adap" |
console_stdout |
Whether to send console output to stdout, otherwise to stderr which is the default of logging. (Output in red text in some IDEs) | Bool True, (*) False |
logging_level |
The minimum level of logs to be recorded. Logs below this level will not be recorded. |
(*) "DEBUG", "INFO", "WARNING", "ERROR", "CRITICAL" |
logging_format |
The level of detail to include in the log message in file. | "simple", (*) "basic", "detail", "adap" |
logfile_savedir |
The absolute path to the directory where log files will be saved. The path should be in either Windows or Linux format. |
String : The OS-specific folder path windows ex) "E:\\Workspace\\sl4p_logs\\app-abc" linux ex) "/opt/my_appvar/data/sl4p_logs/app_abc" |
logfile_name |
The log file name for your application. (default: based on your python program's name) Sl4p will use this prefix to identify and purge old log files. |
String : OS-supported filename. ex) "LOG.your_app_name" |
save_period_type |
The time or size can be set as the criterion for dividing and saving log files. | String : "B", "KB", (*) "MB", "GB" by filesize "S", "M", "H", "D" by time |
save_period_interval |
Specifies the magnitude to use for the selected save_period_type | Int (*) 100 |
save_files_nlimit |
Whether to split and save logs up to a maximum number of files. (Delete excess ones from oldest to newest) | Int (*) 20 |
purge_window_hours |
A window hours that deletes old log files (as much as the hours before the current time) | Int (*) 8800 |
console_colorlog_kwargs |
The dictionary that is passed into initializing colorlog's ColoredFormatter as **kwargs | Dictionary (*) colorlog's default (reference: https://github.com/borntyping/python-colorlog) |
. . . | There are many other options, see sl4p_examples in this branch. |
Make logging
1. Load your configuration
It is important to load your configuration before using your application. I recommend placing this loading config phase at the beginning of your application's main function. Please note that this loading phase only needs to be executed once for the entire application package.
When loading your configuration, you can pass your config (dict or Yaml file's path) as second parameter of getLogger(). Additionally, you can use the optional parameter debugprt=True to display sl4p's initialization info.
Here are three ways to load your configuration:
A. 'get-logger' style loading
log = sl4p.getLogger(__file__, cfg="./applog.cfg", debugprt=True) #debugprt param is optional!
log.info("hello sl4p!")
B. 'with-block' style loading
with sl4p(__file__, cfg=logcfg_dict) as log:
log.info("hello sl4p!")
log.error("Error occured! #%d" % (400))
# log.error("Error occured! ", 400) --> Not support this 'print()' style, Please formatting.
C. How to load logger in Jupyter
__file__
, the first argument of getLogger, is used as an identifier in Snippet logging.
Instead, enter any string in Jupyter.
log = sl4p.getLogger('jupyter', cfg=logcfg_dict):
log.info('Hello sl4p in jupyter!')
2. Write a log message
After loading your configuration, you can log messages anywhere in your application, even in another file or modules, without passing the second parameter into getLogger.
Here are two ways to use logging:
A. 'get-logger' style logging
log = sl4p.getLogger(__file__)
log.debug("Just pass only __file__")
B. 'with-block' style logging
with sl4p(__file__) as log:
log.warning("warn msg! : you should not pass 2nd parameter to sl4p() after configuration completed")
That's it! Enjoy logging your application :)
Remember to load your configuration only once (initial entry-point, recommended) and log your messages everywhere !
Utils & Advanced
The 'with-block' logging feature can measure elapsed time as DEBUG log and can also include a custom tag using tag={TAG_NAME}
.
Here is an example:
import time
with sl4p(__file__, tag='myTag') as log:
time.sleep(1.0)
log.info('with-block time measuring and tagging feature!')
This is the output log:
DEBUG | 2019.11.14-22:03:43 - example2.py #myTag @adfd08e4 started
INFO | 2019.11.14-22:03:44 - with-block time measuring and tagging feature!
DEBUG | 2019.11.14-22:03:44 - example2.py #myTag @adfd08e4 finished ---- Elapsed 1.0001 s
Decorator - @sl4p_time(tag={TAG_NAME})
You can also use the @sl4p_time(tag={TAG_NAME})
decorator to measure the execution time of a function and log it with DEBUG level:
@sl4p_time() # Although you do not use tagging, l4p_time decorator must be written with () brackets.
def my_function1():
time.sleep(1.5)
log.error('not yet...')
This is the output log:
DEBUG | 2019.11.14-22:12:43 - example3.py f`my_function1() @19f19de9 started
ERROR | 2019.11.14-22:12:44 - not yet...
DEBUG | 2019.11.14-22:12:44 - example3.py f`my_function1 @19f19de9 finished ---- Elapsed 1.5038 s
Decorator - @sl4p_try, @sl4p_try_exit
you can use the @sl4p_try
and @sl4p_try_exit
decorator to try-except your function and log the traceback of the exception.
@sl4p_try
def take_exception():
a = 'ABCD' + None
This is the output log:
ERROR | 2019.11.14-22:12:44 - can only concatenate str (not "NoneType") to str
Traceback (most recent call last):
File "D:\Devel_Workspace\py27_9\devel_logger\sl4p\decorators.py", line 21, in wrapped
return func(*args, **kwargs)
File "D:/Devel_Workspace/py27_9/devel_logger/example3.py", line 15, in take_exception
a = 'ABCD' + None
TypeError: can only concatenate str (not "NoneType") to str
Remember @sl4p_try
will continue the program when excepted, but @sl4p_try_exit
will terminate it.
About
Python version compatibility
3.1 ~
Dependencies
- json
- psutil
- colorlog
- pywin32 (only in windows)
- colorama (only in windows)
License
BSD 3
Getting Help / Discussion / Contributing
Right here, please be active in this GitHub repository.
All contributions, bug reports, bug fixes, documentation improvements, enhancements, and ideas are welcome.
Release Note
(*) ver1.4.4 :: Deprecate imp
and replace it with importlib
(imp is removed from python 3.12)
ver 1.4.3 :: Prevented logfile name starting with . (period)
ver 1.4.2 :: Coloring console log (by colorlog) and add related configs, Support console stdout'
ver 1.4.1 :: Correct the docs, Change default config (console config has no initial values)
ver 1.4.0 :: Layered apps-config, Support console level&format, IndLogger, Enhance stability
ver 1.3.3linux :: excluding 'psutil' in requires for linux
ver 1.3.3 :: override_dict bugfix (support python 3.9+)
ver 1.3.2 :: Add log_level for SimpleTimer: logger.create_simpleTimer(), config bugfix
ver 1.3.1 :: Add log_level for @sl4p_time decorator
ver 1.2.0 :: Add stopwatch(SimpleTimer), Profiling stats(CPU & MEM), Recording TimeZone
ver 1.0.1 :: Supports multi-byte msg, update config and constants / Patch debugprt, start_ts
ver 1.0.0 :: First deployed release version
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 Distributions
Built Distributions
File details
Details for the file sl4p-1.4.4-py3-none-win_amd64.whl
.
File metadata
- Download URL: sl4p-1.4.4-py3-none-win_amd64.whl
- Upload date:
- Size: 23.0 kB
- Tags: Python 3, Windows x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f6d59b7bc041d09173950d938eac8760be7ec30a7e29ad2a9c5008edd1622ecb |
|
MD5 | 854be8e90047fe2f34b7bb8e94762ff6 |
|
BLAKE2b-256 | 31ea170ff5f8f69c7bb2194d901264f3e8c6be51cca23cf8a02026e3d06041a9 |
File details
Details for the file sl4p-1.4.4-py3-none-manylinux1_x86_64.whl
.
File metadata
- Download URL: sl4p-1.4.4-py3-none-manylinux1_x86_64.whl
- Upload date:
- Size: 22.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 949488957f5560d13260eacd2970b6a7c20d0c903b812feb02cb9156f996aa50 |
|
MD5 | 8e241c2beaecd0188e7691ae5309d0a4 |
|
BLAKE2b-256 | 2fb1e20205678fc76f828a4c4cbe83db3a2b82f57e7a7a7e9a99ccb21415d7fb |
File details
Details for the file sl4p-1.4.4-py3-none-any.whl
.
File metadata
- Download URL: sl4p-1.4.4-py3-none-any.whl
- Upload date:
- Size: 23.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.11.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6aceb4aaef336da43e6315270ef9206350e161b01c1990709a25f3d753a98c53 |
|
MD5 | c52a914c257717c365a62adcf61df2af |
|
BLAKE2b-256 | 9894be206e14df81f6097c2f666b6277224906915fa57c2d5bb4816255a3ee3b |