Froggius is a lightweight and dumb easy logging libary for python
Froggius is a lightweight python libary, which is designed for easy to use logging for all your programs. It makes it easy for everybody, but also brings a lot of options to configure it like you need it. An very interesting feature for example is the error catching for functions, which makes it easy to log unexpected errors, warnings etc.
Froggius is like in the introduction already said very lightweight and designed for efficiency, which means that the speed of the logging is much faster than other libarys. How fast it is, can you see in this line chart:
This example runs following debug command 60 times and prints every time the log to the console and stdout:
logger.debug('Example Debug Message')
This massive speed improvement helps your program, to log like you need it without performance disadvantages.
System informations: MacOS Sonoma 14.4.1, MacBook Air M2, Python 3.12.1
You can install Froggius with following command:
pip install froggius
Alternatively you can clone this repository and install then:
git clone https://github.com/zlElo/Froggius.git
cd Froggius
pip install .
Here are examples for the usage of Froggius. Import statement is following:
from froggius import Froggius
logger = Froggius()
Use it as debugger/logger with following possible arguments:
- log_msg (log message)
- file_path (None by default, used to set up a log file [...] to append to this file. The file does not have to already exist, if it does not exist, it will be created)
- print_out (True by default, used to setup printing to console and stdout)
# Example normal logging
logger.debug('This is a normal debug log')
# This writes the log to a log file
logger.debug('This is a normal debug log', 'tests/example.log', print_out=False)
Use it as error logger with following possible arguments:
- log_msg (log message)
- file_path (None by default, used to set up a log file [...] to append to this file. The file does not have to already exist, if it does not exist, it will be created)
- highliting (True by deafult, used to colorize [DBG] etc.)
- print_out (True by default, used to setup printing to console and stdout)
- line (None by default, expects list with following 3 items in this structure: [line number, file name, function name])
# Example error
logger.error('This is an error log')
# This writes the error to a log file
logger.error('This is an error log', 'tests/example.log', print_out=False)
Use it as information logger with following possible arguments:
- log_msg (log message)
- file_path (None by default, used to set up a log file [...] to append to this file. The file does not have to already exist, if it does not exist, it will be created)
- highliting (True by default, used to colorize [INF] etc.)
- print_out (True by default, used to setup printing to console and stdout)
# Example information
logger.information('This is an information log')
# This writes the information to a log file
logger.information('This is an information log', 'tests/example.log', print_out=False)
Use it as warning logger with following possible arguments:
- log_msg (log message)
- file_path (None by default, used to set up a log file [...] to append to this file. The file does not have to already exist, if it does not exist, it will be created)
- highliting (True by default, used to colorize [WRN] etc.)
- print_out (True by default, used to setup printing to console and stdout)
# Example warning
logger.warning('This is a warning log')
# This writes the warning to a log file
logger.warning('This is a warning log', 'tests/example.log', print_out=False)
Use the catching errors methode, to catch and handle unexpected errors, warnings etc:
@logger.catch(file_path='tests/example.log')
def example_function():
"""
Information: Not working function, because of division by zero
"""
var1 = 5
var = 0
result = var1 / var
print(result)
example_function()
Output in log file:
[ERR] [01/04/2024 09:15:00] division by zero | Occured on line: 28 in /Users/username/path/examples.py, example_function()
If you want to configure the file_path and the print_out for everything, you can do that with following line before all other Froggius statements:
# configure print_out and file_path for everything
logger = Froggius(print_out=False, file_path='tests/example.log')
logger.debug('Test normal')
logger.error('Test error')
logger.information('Test information')
It's also possible to say, that you want that all is not printed, but this logger.debug('Test normal')
or logger.information('Test information')
. Just work with the available parameters:
# configure print_out and file_path for everything
logger = Froggius(print_out=False, file_path='tests/example.log')
logger.debug('Test normal', print_out=True) # everything is not printed, but this line is printed
logger.error('Test error')
logger.information('Test information')