logging 输出json

import logging
import datetime
import json

logging.basicConfig(
    filename='example.json',
    level=logging.DEBUG,
    # format='%(asctime)s:%(levelname)8s:%(name)10s:%(message)s',
    format='%(message)s'
    # datefmt='%Y/%m/%d %I:%M:%S'
)

logger = logging.getLogger(__name__)


def obj_format(obj=None, level=logging.DEBUG, timestamp=True, modle_name=False):
    '''
    
    :param obj: 字典类型对象, 写到es的数据格式.
    :param level: 调用logger模块是的日志级别,默认为debug.
    :param timestamp: 默认会添加创建时间,utc时间.
    :param modle_name: 默认会添加本模块的__name__变量.
    :return: 对obj序列化为字符串, 传给logger的message变量.
    '''
    
    if not obj:
        raise 'obj is None'
    
    # if not type(obj) is dict:
    #     raise 'type(obj) must be dict'
    if not isinstance(obj, dict):
        raise 'type(obj) must be dict'
    
    if timestamp:
        obj['timestamp'] = datetime.datetime.utcnow().isoformat()
        
    if modle_name:
        obj['name'] = __name__
    
    obj['level'] = logging.getLevelName(level)
    return json.dumps(obj)


def main():
    # logger.info(obj_format({1: 'hello'}, logging.INFO))
    logger.debug(obj_format({'msg': 'hello'}))


if __name__ == '__main__':
    main()

转载于:https://my.oschina.net/tplinuxhyh/blog/1544378

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值