A colorful logger for python3.
Project description
:warning: This README is translated by Google. If there is a grammatical error, please open an issue to correct it!
python-logger
Colorful logger for python3
How to use
Install
pip install colorful-logger
Usage
1 default logger
You can directly use the default logger, the colored logs will be printed on the terminal, and the default logger level is warning.
from colorful_logger import logger
with logger:
logger.debug("default logger")
logger.info("default logger")
logger.warning("default logger")
logger.error("default logger")
As you can see, logger
needs to be executed in the with
statement, because this package uses QueueListener
to call log output. You need to call the start
method before using logger
to output the log, and you need to call the stop
after the end of use. I encapsulated these two methods in the with
statement. In non-special scenarios, there is no need to call the start
and stop
methods separately.
2 custom logger
You can also change the log level, save the log to a file, change the logger name, and the log may not be output to the terminal.
from colorful_logger import get_logger, DEBUG
def demo_logger(to_file=False):
file = "test_%d.log"
l1 = get_logger(
"demo",
DEBUG,
add_file_path=False,
disable_line_number_filter=False,
file_path=file % 1 if to_file else None,
)
with l1:
l1.debug("without file path")
l1.info("without file path")
l1.warning("without file path")
l1.error("without file path")
l2 = get_logger(
"demo",
DEBUG,
add_file_path=True,
disable_line_number_filter=False,
file_path=file % 2 if to_file else None,
)
with l2:
l2.debug("with file path")
l2.info("with file path")
l2.warning("with file path")
l2.error("with file path")
l3 = get_logger(
None,
DEBUG,
add_file_path=True,
disable_line_number_filter=True,
file_path=file % 3 if to_file else None,
)
with l3:
l3.debug("without name, and with path")
l3.info("without name, and with path")
l3.warning("without name, and with path")
l3.error("without name, and with path")
l4 = get_logger(
None,
DEBUG,
add_file_path=False,
disable_line_number_filter=True,
file_path=file % 4 if to_file else None,
)
with l4:
l4.debug("without name and path")
l4.info("without name and path")
l4.warning("without name and path")
l4.error("without name and path")
There may be unexpected situations when outputting logs outside of the with
statement, which may not achieve the expected results.
The content of the log file ./test.log
(example, inconsistent with the information in the above figure):
[90m10:09:33.146[0m [35mDEB[0m [36mdemo[0m[1m:26[0m [96m-[0m without file path
[90m10:09:33.146[0m [32mINF[0m [36mdemo[0m [96m-[0m without file path
[90m10:09:33.146[0m [33mWAR[0m [36mdemo[0m [96m-[0m without file path
[90m10:09:33.146[0m [91mERR[0m [36mdemo[0m[1m:29[0m [96m-[0m without file path
The log output to the file is not a color log by default.
If you need to save the color log in a file, set the file_colorful
parameter to True
. In this example, the color log is saved.
The color log file has only one function, which is to view the real-time log in the terminal:
- Unix
tail -f test.log
# 或
cat test.log
- Windows
Get-Content -Path test.log
3 child logger
After defining a logger
, I want to use all the parameters of this logger
except name
to output the log. At this time, you need to use the child_logger
method to generate a child logger. The child logger needs to be in the with
of the parent logger Execute in the statement:
from colorful_logger import get_logger, DEBUG
# parent logger
logger = get_logger(name="sample_logger", level=DEBUG, file_path="./test.log")
with logger:
logger.error("parent error")
l1 = logger.child("l1")
l1.error("l1 error")
l1.fatal("l1 fatal")
The child logger is the same except that the name is different from the parent logger, and it will not output the log of the third-party library.
The execution of the child logger in the with
statement of the parent logger does not mean that it must be called directly in the with
statement. It can be executed in a function in the with
statement, such as:
# log.py
from colorful_logger import get_logger, DEBUG
logger = get_logger(name="sample_logger", level=DEBUG, file_path="./test.log")
# main.py
from log import logger
from other_file import test
with logger:
test()
# other_file.py
test_logger = logger.child("test_logger")
def test():
test_logger.error("test error")
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
Built Distribution
File details
Details for the file colorful-logger-0.1.13.tar.gz
.
File metadata
- Download URL: colorful-logger-0.1.13.tar.gz
- Upload date:
- Size: 13.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.16
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5a34983d496ef65f4b96991c56f34fccda30e966593d05c04b484fa26e9f30d1 |
|
MD5 | fd0a087afc9c3b186a5fcc10f505cf3d |
|
BLAKE2b-256 | 6fc0a3081036a1213bc10a22e1d1e3d1cbca2c996473d72ed53f6c53bf6ede4b |
File details
Details for the file colorful_logger-0.1.13-py3-none-any.whl
.
File metadata
- Download URL: colorful_logger-0.1.13-py3-none-any.whl
- Upload date:
- Size: 11.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.16
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3cc2a9cff1f713cfdff3a3c36ffc19ce636b084911ce234f23a76feeda83bf62 |
|
MD5 | 6a102db7f0275d3ebabd061802f2b7f3 |
|
BLAKE2b-256 | 9a1999dced161f158a3f0bdf37d8cca82199cb02172e58af34142400c46f048a |