python的logging主要有四个组件: * logger: 日志类,应用程序往往通过调用它提供的api来记录日志; * handler: 对日志信息处理,可以将日志发送(保存)到不同的目标域中; * filter: 对日志信息进行过滤; * formatter:日志的格式化;
logging是线程安全的。
默认情况下,logging将日志打印到屏幕,日志级别为WARNING。日志级别大小关系为:CRITICAL > ERROR > WARNING > INFO > DEBUG > NOTSET。
# -*- coding: utf-8 -*-import logginglogging.debug('This is debug message')logging.info('This is info message')logging.warning('This is warning message')输出
WARNING:root:This is warning message当前目录下test.log内容:
Tue, 07 Feb 2017 19:51:36 python-logging.py[line:10] DEBUG This is debug messageTue, 07 Feb 2017 19:51:36 python-logging.py[line:11] INFO This is info messageTue, 07 Feb 2017 19:51:36 python-logging.py[line:12] WARNING This is warning messagelogging.basicConfig函数各参数: - filename: 指定日志文件名 - filemode: 和file函数意义相同,指定日志文件的打开模式,’w’或’a’ - format: 指定输出的格式和内容,format可以输出很多有用信息,如上例所示: - %(levelno)s: 打印日志级别的数值 - %(levelname)s: 打印日志级别名称 - %(pathname)s: 打印当前执行程序的路径,其实就是sys.argv[0] - %(filename)s: 打印当前执行程序名 - %(funcName)s: 打印日志的当前函数 - %(lineno)d: 打印日志的当前行号 - %(asctime)s: 打印日志的时间 - %(thread)d: 打印线程ID - %(threadName)s: 打印线程名称 - %(PRocess)d: 打印进程ID - %(message)s: 打印日志信息 - datefmt: 指定时间格式,同time.strftime() - level: 设置日志级别,默认为logging.WARNING - stream: 指定将日志的输出流,可以指定输出到sys.stderr,sys.stdout或者文件,默认输出到sys.stderr,当stream和filename同时指定时,stream被忽略
当前目录下test.log内容:
Tue, 07 Feb 2017 19:56:23 python-logging.py[line:19] DEBUG This is debug messageTue, 07 Feb 2017 19:56:23 python-logging.py[line:20] INFO This is info messageTue, 07 Feb 2017 19:56:23 python-logging.py[line:21] WARNING This is warning message控制台输出:
root : INFO This is info messageroot : WARNING This is warning message将日志同时输出到文件和屏幕的例子:
# -*- coding: utf-8 -*-import logging.configlogging.config.fileConfig("logger.conf")logger = logging.getLogger("example01")logger.debug('This is debug message')logger.info('This is info message')logger.warning('This is warning message')日志回滚的例子:
# -*- coding: utf-8 -*-import logging.configlogging.config.fileConfig("logger.conf")logger = logging.getLogger("example02")logger.debug('This is debug message')logger.info('This is info message')logger.warning('This is warning message')新闻热点
疑难解答