格式化 Django 管理命令日志记录

max*_*max 5 django

我有这个 Django 设置:

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'filters': {
        'require_debug_false': {
            '()': 'django.utils.log.RequireDebugFalse'
        }
    },
    'handlers': {
        'mail_admins': {
            'level': 'DEBUG',
            'filters': ['require_debug_false'],
            'class': 'django.utils.log.AdminEmailHandler'
        }
    },
    'loggers': {
        'django.request': {
            'handlers': ['mail_admins'],
            'level': 'DEBUG',
            'propagate': True,
        },
    }
}
Run Code Online (Sandbox Code Playgroud)

在我的管理命令代码中,我必须将其放入调试级别日志:

import logging
logger = logging.getLogger('main')
logger.setLevel(logging.DEBUG)
Run Code Online (Sandbox Code Playgroud)

但我还想添加日期,所以我尝试了:

import logging
logger = logging.getLogger('main')
logger.setLevel(logging.DEBUG)
ch = logging.StreamHandler()
formatter = logging.Formatter('%(asctime)s %(levelname)s: %(message)s')
ch.setFormatter(formatter)
logger.addHandler(ch)
Run Code Online (Sandbox Code Playgroud)

这会导致事情被记录两次,例如:

2016-03-14 22:32:16,202 DEBUG: test
DEBUG: test
Run Code Online (Sandbox Code Playgroud)

如何为管理命令格式化记录器?