文件处理程序的不同日志记录级别和Python中的显示

时间:2011-07-11 15:40:39

标签: python logging

我在Python中使用logging模块来编写调试和错误消息。

我想写入logging.DEBUG或更高版本的所有邮件。

但是,我只想打印logging.WARNING或更高版本的屏幕消息。

只使用一个Logger和一个FileHandler吗?

4 个答案:

答案 0 :(得分:12)

正如已经提到的那样,处理程序很容易创建和添加,你可能最好只使用两个处理程序。但是,如果由于某种原因你想要坚持一个,Python logging cookbook有一个部分描述你想要做的事情:记录到控制台和文件,但在不同的级别(它甚至告诉你如何做不同的格式化)。不过,它只使用一个StreamHandler而不是FileHandler

import logging

# set up logging to file - see previous section for more details
logging.basicConfig(level=logging.DEBUG,
                    format='%(asctime)s %(name)-12s %(levelname)-8s %(message)s',
                    datefmt='%m-%d %H:%M',
                    filename='/temp/myapp.log',
                    filemode='w')
# define a Handler which writes INFO messages or higher to the sys.stderr
console = logging.StreamHandler()
console.setLevel(logging.INFO)
# set a format which is simpler for console use
formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
# tell the handler to use this format
console.setFormatter(formatter)
# add the handler to the root logger
logging.getLogger('').addHandler(console)

# Now, we can log to the root logger, or any other logger. First the root...
logging.info('Jackdaws love my big sphinx of quartz.')

# Now, define a couple of other loggers which might represent areas in your
# application:

logger1 = logging.getLogger('myapp.area1')
logger2 = logging.getLogger('myapp.area2')

logger1.debug('Quick zephyrs blow, vexing daft Jim.')
logger1.info('How quickly daft jumping zebras vex.')
logger2.warning('Jail zesty vixen who grabbed pay from quack.')
logger2.error('The five boxing wizards jump quickly.')

编辑:正如评论中所讨论的,此代码仍会生成两个处理程序,但通过使用basicConfig()“隐藏”一个构造。我强烈建议你明确地创建它们。

答案 1 :(得分:2)

没有。文件和屏幕输出意味着您需要两个处理程序。

答案 2 :(得分:0)

您可以使用相同的处理程序。此示例使用log.debug()和log.info()将消息记录到文件中,并将它们记录到控制台中:

log = logging.getLogger("syslog2elastic")
log.setLevel(logging.DEBUG) # this must be DEBUG to allow debug messages through

console = logging.StreamHandler()
console.setLevel(logging.INFO)
formatter = logging.Formatter("%(asctime)s.%(msecs)03d - %(name)s:%(lineno)d - %(levelname)s - %(message)s", "%Y%m%d%H%M%S")
console.setFormatter(formatter)
log.addHandler(console)

fh = RotatingFileHandler(args.logfile, maxBytes=104857600, backupCount=5)
fh.setLevel(logging.DEBUG)
formatter = logging.Formatter("%(asctime)s.%(msecs)03d - %(message)s", "%Y%m%d%H%M%S")
fh.setFormatter(formatter)
log.addHandler(fh)

答案 3 :(得分:0)

您可以通过以下方式执行此操作,制作两个记录器,一个用于文件日志记录,另一个用于控制台日志记录。确保将根记录器设置为两者中最详细的。

import logging

logging.getLogger().setLevel(logging.DEBUG)  # This must be as verbose as the most verbose handler

formatter = logging.Formatter(
    '%(asctime)s.%(msecs)03d %(levelname)s %(module)s - %(funcName)s [%(lineno)s]: %(message)s',
    datefmt='%Y-%m-%d %H:%M:%S',
)

console_logging = logging.StreamHandler()
console_logging.setLevel(logging.WARNING)
console_logging.setFormatter(formatter)
logging.getLogger().addHandler(console_logging)

file_logging = logging.FileHandler('file.log')
file_logging.setLevel(logging.DEBUG)
file_logging.setFormatter(formatter)
logging.getLogger().addHandler(file_logging)
相关问题