u can do this with logging.LoggerAdapter
myLogger = logging.LoggerAdapter(logging.getLogger("my-logger"), {"username" : get_user_name()})
. dict . ,
def get_user_name():
return session.get("username", "")
LOGGING = {
'version': 1,
'disable_existing_loggers': True,
'formatters': {
'my_format': {
'format': '%(username)s - %(asctime)s %(levelname)-10s %(message)s [in %(pathname)s:%(lineno)d]'
},
},
'handlers': {
'my_handler': {
'level': 'DEBUG',
'class': 'logging.handlersRotatingFileHandler',
'filename': fname,
'maxBytes': 1 * 1024 * 1024,
'backupCount': 5,
},
},
'loggers': {
'my_logger': {
'handlers': ['my_handler'],
'propagate': True,
'level': 'DEBUG',
},
} }
logging.config.dictConfig(LOGGING)
logging.LoggerAdapter(logging.getLogger('my_logger'),
{"username" : get_user_name()})