相关疑难解决方法(0)

如何将自定义字段添加到Python日志格式字符串?

我当前的格式字符串是:

formatter = logging.Formatter('%(asctime)s : %(message)s')
Run Code Online (Sandbox Code Playgroud)

我想添加一个名为app_name的新字段,它将在包含此格式化程序的每个脚本中具有不同的值.

import logging
formatter = logging.Formatter('%(asctime)s %(app_name)s : %(message)s')
syslog.setFormatter(formatter)
logger.addHandler(syslog)
Run Code Online (Sandbox Code Playgroud)

但我不知道如何将该app_name值传递给记录器以插入格式字符串.我显然可以让它出现在日志消息中,但每次都传递它,但这很麻烦.

我试过了:

logging.info('Log message', app_name='myapp')
logging.info('Log message', {'app_name', 'myapp'})
logging.info('Log message', 'myapp')
Run Code Online (Sandbox Code Playgroud)

但没有工作.

python logging

68
推荐指数
6
解决办法
4万
查看次数

Django在格式化程序中记录自定义属性

Django如何使用格式化程序中的自定义属性使用日志记录?我正在考虑记录登录的用户名,例如.

settings.py脚本中,定义了LOGGING变量:

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'filters': {
        'require_debug_false': {
            '()': 'django.utils.log.RequireDebugFalse'
        },
    },
    'formatters' : {
        'info_format' : {
            'format' : '%(asctime)s %(levelname)s - %(message)s',
        },
    }
}
Run Code Online (Sandbox Code Playgroud)

我希望使用一种格式,例如:

'format' : '%(asctime).19s %(levelname)s - %(username)s: %(message)s'
Run Code Online (Sandbox Code Playgroud)

用户名将是当前登录的用户.也许在这里可以添加任何其他类型的会话变量.

这里的解决方法是extra在logger方法上使用该参数,该方法接收一个字典,其中键作为我想在格式字符串上使用的字符串:

logger.info(message, extra={'username' : request.user.username})
Run Code Online (Sandbox Code Playgroud)

另一个(丑陋的)解决方法是构建message属性以包含不属于记录格式化程序的默认属性的内容.

message = request.user.username + " - " + message
logger.info(message)
Run Code Online (Sandbox Code Playgroud)

但是,有没有办法设置具有某些属性的格式字符串,并使Django自动将它们提供给日志记录API?如果%(username)s,例如request.user.username,则可能是其他任何人...

python django logging

17
推荐指数
1
解决办法
3809
查看次数

标签 统计

logging ×2

python ×2

django ×1