zoukankan      html  css  js  c++  java
  • logz-易用的日志记录器

    logz-易用的日志记录器

    easy use for log with extra infos

    特性

    • very easy to use
    • log file name change from date
    • DayRottingLogger
    • safe extra fields
    • log multi vars and not just str
    • multiline log and indent for json
    • debug as default level

    Install

    $ pip install logz
    

    Use

    Simple Use

    from logz import log
    log.debug('debug msg')
    log.info('info msg')
    log.warning('warning msg')
    log.error('error msg')
    log.critical('critical mst')
    try:
        assert 0
    except AttributeError as ex:
        log.exception(ex)
    

    output:

    2019-12-12 22:39:43,584 DEBUG debug msg
    2019-12-12 22:39:43,584 INFO info msg
    2019-12-12 22:39:43,584 WARNING warning msg
    2019-12-12 22:39:43,585 ERROR error msg
    2019-12-12 22:39:43,585 CRITICAL critical mst
    Traceback (most recent call last):
      File "/Users/apple/Documents/Projects/logz/logz/__init__.py", line 199, in <module>
        assert 0
    AssertionError
    

    log multi vars one time

    a = 'hello'
    b = 1
    c = [2]
    d = {'name': 'kevin'}
    log.info(a,b,c,d)
    

    output:

    2019-12-12 22:40:20,221 INFO hello 1 [2] {'name': 'kevin'}
    

    Note: Change args form supporting %s format to supporting multi vars
    if you want to use something like:

    import logging
    logging.info('name=%s,age=%d', 'kevin',18)
    

    you neet use like below:

    form logz import log
    log.info('name=%s,age=%d' % ('kevin',18))
    

    output:

    2019-12-12 22:41:58,024 INFO name=kevin,age=18
    

    log to file

    log.file='logs/project.log'
    

    Note: logs directory must be exists

    By default it's a rotting file and maxBytes=10240 and backUps=5

    log to a file with name changes with date

    log.file='logs/%Y-%m-%d.log'
    

    And it's a day rotting file

    change log level

    log.level = 'info'
    log.level = 20
    log.debug('not show')
    log.info('show info')
    

    output:

    2019-12-12 22:43:24,479 INFO show info
    

    level string is not case sensitive

    change log format

    log.format = '%(asctime)s %(levelname)s %(name)s %(message)s'
    

    with extra fields

    log.format = '%(asctime)s %(levelname)s %(user)s %(message)s'
    log.info('hello with no user')
    log.info('hello with kevin', extra={'user': 'kevin'})
    

    output:

    2019-12-12 22:45:18,604 INFO None hello with no user
    2019-12-12 22:45:18,604 INFO kevin hello with kevin
    

    multiline and indent for dict

    log.info({'foo': 'bar'}, indent=2)
    

    output:

    2019-12-09 19:30:16,419 DEBUG log None ->
    {
      "foo": "bar"
    }
    

    todo

    • log file to config maxBytes or else
    • log to html
    • log to email
    • log to db
    • log diff
    • log assert
    • log print
    • log to server using websocket
    • more decorators such as @explain @exception @timeit @email
    • support verbosity

    Bugs

    • logit not support instance method
  • 相关阅读:
    SDOI2008Cave 洞穴勘测
    使用Nginx反向代理和内容替换模块实现网页内容动态替换功能
    使用Nginx反向代理和内容替换模块实现网页内容动态替换功能
    Js 变量声明提升和函数声明提升
    Js 变量声明提升和函数声明提升
    Golang-filepath使用
    Golang-filepath使用
    44、File类简介
    44、File类简介
    div/dom元素拖拽缩放插件,纯js实现拖拽缩放,不依赖jQuery~
  • 原文地址:https://www.cnblogs.com/superhin/p/12737843.html
Copyright © 2011-2022 走看看