python logging.getlogger,python – 避免`logger = logging.getLogger(__ name __)`

您可以使用logging.basicConfig通过日志记录定义可用的默认界面,如下所示:

import logging

logging.basicConfig(level=logging.DEBUG,

format='%(asctime)s %(name)s.%(funcName)s +%(lineno)s: %(levelname)-8s [%(process)d] %(message)s',

)

当您在应用程序中执行以下任何操作时,现在将使用此定义:

import logging

logging.error(...)

虽然__name__不可用,但通过默认的LogRecord attributes可以使用等效(和其他选项),可用于错误字符串格式 – 包括模块,文件名和路径名。以下是一个双脚本演示:

scripta.py

import logging

logging.basicConfig(level=logging.DEBUG,

format='%(asctime)s %(module)s %(name)s.%(funcName)s +%(lineno)s: %(levelname)-8s [%(process)d] %(message)s',

)

from scriptb import my_view

my_view()

scriptb.py

import logging

def my_view():

# Log an error message

logging.error('Something went wrong!')

日志记录定义在scripta.py中定义,并添加了模块参数。在scriptb.py中,我们只需要导入日志记录即可访问此定义的默认值。运行scripta.py时会生成以下输出:

2016-01-14 13:22:24,640 scriptb root.my_view +9: ERROR [14144] Something went wrong!

其中显示了发生错误日志记录的模块(scriptb)。

根据this answer,您可以通过关闭Django处理和设置根处理程序,从Django继续使用任何每模块配置的日志记录,如下所示:

# settings.py - django config

LOGGING_CONFIG = None # disables Django handling of logging

LOGGING = {...} # your standard Django logging configuration

import logging.config

logging.config.dictConfig(LOGGING)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值