我有这个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,
},
}
}
在我的管理命令代码中,我不得不将其记录在调试级别:
import logging
logger = logging.getLogger('main')
logger.setLevel(logging.DEBUG)
但我想添加日期,所以我尝试了:
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)
这导致事情被记录两次,如:
2016-03-14 22:32:16,202 DEBUG: test
DEBUG: test
如何格式化管理命令的记录器?