Skip to main content

Log library

Project description

SmileLog

smilelog SmileLog 4.1.4
Appending a silent feature which auto-remove itself the current content file if over a limit that given by a parameter 'maxMb'. It won't do anything unless the value of the 'autoclean' equals 'False'.

autoclean= True
maxMb=100

Every writing a log, it will check these value.

The features since version 4.x.x:

  • Log to a static file
  • Backup file everyday
  • Enable series of log session
  • Parallel log between static log and session log
  • Push any log to redis via pubsub method
  • Dynamic line separation
    • on or off
    • editable line character
    • editable number of line character
  • Fix bugs
  • Improve performance
  • Clean up code

It's going to change the traditional tracing in another way.
What will it assist us:

  1. Showing the colorized log by following the standard color
  2. Ignoring any track by reading id in the list
  3. Each statement list down with a big span and symbols
  4. Using a static file to output the content that will be easier
  5. Disable the entire tracing in a second
  6. 5 methods for 5 outputs
  7. Backup file if log start a new date
  8. Separating a new file with a new file name This feature will cover to a specific tracking.
  9. Group the log with specific key(series key)
  10. Able to set maxSize log

It is available on PyPi store via https://pypi.org/project/SmileLog/
To Support my work, please donate me via Buy me a PizzaBuy me a Coffee

Installation

# pip3 install SmileLog

5 Methods

Use in the different situation, and show up in different color

  1. error: error(title, content, id= None, channel= None)
  2. fail: fail(title, content, id= None, channel= None)
  3. information: info(title, content, id= None, channel= None)
  4. success: success(title, content, id= None, channel= None)
  5. track: track(title, content, id= None, channel= None)
  6. warning: warning(title, content, id= None, channel= None)
- title is a string
- content can be a string or dict
Figure (version 2.0)

smilelog-output

Start using in the simple way:

from smilelog import Logger


# first instant
log	= Logger(
            enableLog= True
	)

# try to print out
log.info(
	'My Info Title'
	, {'data':'My Dictionary Content'}
)

# success method
log.success(
	title	 	= 'My Success Title'
	, content	= 'My String'
)

# setKeySeries is a new method to indicate to the token of a long message
log.setKeySeries('NbcseX32cDse')

Logger

Logger is a tracing class library and write/output into a file.
This will need generating a file and keep writing the content. Let's Look at its configure would explain more:

log	= Logger(
           path:                str	= 'log'
           , filename: 			str = 'access'
           , extension: 		str = 'log'  
            , enableLog: 		bool= True
            , enableConsole:    bool= True
            , line: 			bool= True
            , charInLine: 		int	= 55
            , lineCharStart:    str = '>'
            , lineCharEnd: 		str = '<',
            , color: 			bool= True
            , autoClean:        bool= False
            , maxMb:            int=100
	)
  • path: is a directory
Ex:
/var/www/my-project/logs/

  • filename: is the name of a new file log.
# set name
filename= 'access'

Ex: 
/var/www/my-project/logs/access.log 
# some app move it into system log directory, it is an advantage of prefix

  • color: is for showing the color on terminal with tail command or terminal editor.
# set color
color= True
or
color= False
  • enableLog: allow an object to create the file.
    • True: To create a file and write content into log file
    • False: To disable the logging
# set enable
# enable to write log file
enableLog= True
  • enableConsole: to bring something on the screen of log.
    • True: To print out on terminal
    • False: No action
# set enable
enableConsole= True

Series

Just a series name of output

  • setKeySeries: data
# set value
log.setKeySeries('Insert Data')
# stop
log.setKeySeries()

Disable print out

The most feature developer guy needs.
It will disable only the index that we set in disable list.

  • disableIds: hide those ids.
    • parameter must be Array
# Logger instant
# Ex: Logger logged 10 times
# but we will show some id except 1,2,3,7,8,9
# do this
log.disableIds([1,2,3,7,8,9])

Separate a session file

Here is the method to separate normal log file to a specific. Follow the setting:

  • setKeySession: must be a string and maximum length 32
log.setKeySession('cbc98494543823442425488df')

It will separate from the default log, and generate a new file as 'cbc98494543823442425488df.log'.

Note:

To stop running a session, just set it the None.

log.setKeySession()

2022-05-12 21:40:20.345 <id: 4>
_>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
[FAIL] My Title
{'data': 'my content'}
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

2022-05-12 21:40:20.345 <id: 5> Insert Data
_>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
[WARNING] Warning
{'data': 'my content'}
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

2022-05-12 21:40:20.345 <id: 6> Delete Row
[TRACK] My Title
{'data': 'my content'}

2022-05-12 21:40:20.345 <id: 10>
[SUCCESS] Success
Hello String

Pub/Sub

initializes redis requirement

  • setRedis
    • host: required
    • port: required
    • channel: the default is None, scribe and publish
    • db: by default is 0
    • password: by default is None

enable Redis Engine

  • enableRedis: bool

enable any functional alert

  • enableError: bool
  • enableFail: bool
  • enableInfo: bool
  • enableTrack: bool
  • enableSuccess: bool
  • enableWarning: bool

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

SmileLog-4.1.4.tar.gz (10.6 kB view details)

Uploaded Source

Built Distribution

SmileLog-4.1.4-py3-none-any.whl (11.9 kB view details)

Uploaded Python 3

File details

Details for the file SmileLog-4.1.4.tar.gz.

File metadata

  • Download URL: SmileLog-4.1.4.tar.gz
  • Upload date:
  • Size: 10.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.13

File hashes

Hashes for SmileLog-4.1.4.tar.gz
Algorithm Hash digest
SHA256 854d963b46eb381be0b75e56f8c3438b821a0714a711e225c76c7d99c76d7601
MD5 bfa6502fe083cfb4bccc8d0dbae34363
BLAKE2b-256 c6e7fa5606db809cdee754a125430f547e247c9cde0884d22da4fff4a2e3a2ff

See more details on using hashes here.

File details

Details for the file SmileLog-4.1.4-py3-none-any.whl.

File metadata

  • Download URL: SmileLog-4.1.4-py3-none-any.whl
  • Upload date:
  • Size: 11.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.13

File hashes

Hashes for SmileLog-4.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 c306b41accb8969b0e96b2ed3214dafeccb2f42f8dc23d61ce8117d13b81077c
MD5 206646af3b0def20f7833a01a6413a40
BLAKE2b-256 5c1f1feda8913fc4b9992f6e53e79fb724dab2868e6d21e1fa91448fd065cd5b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page