vim logger_config.ini
[loggers]
keys=root,infoLogger,errorlogger
[logger_root]
level=DEBUG
handlers=infohandler,errorhandler
[logger_infoLogger]
handlers=infohandler
qualname=infoLogger
propagate=0
[logger_errorlogger]
handlers=errorhandler
qualname=errorlogger
propagate=0
###############################################
[handlers]
keys=infohandler,errorhandler
[handler_infohandler]
class=StreamHandler
level=INFO
formatter=form02
args=(sys.stdout,)
[handler_errorhandler]
class=FileHandler
level=ERROR
formatter=form01
args=('logs/mylog.log', 'a')
###############################################
[formatters]
keys=form01,form02
[formatter_form01]
format=%(asctime)s %(filename)s %(levelname)s %(message)s
datefmt=%Y-%m-%d %H:%M:%S
[formatter_form02]
format=%(asctime)s %(filename)s %(levelname)s %(message)s
datefmt=%Y-%m-%d %H:%M:%S
字段說明:
[loggers]
# 定義logger模塊,root是父類,必需存在的,其它的是自定義。
# logging.getLogger(NAME)便相當於向logging模塊注冊了一種日志打印
# name 中用 . 表示 log 的繼承關系
[handlers]
# 定義handler
[formatters]
# 定義格式化輸出
# 定義格式化輸出
[logger_root]
# 實現上面定義的logger模塊,必需是[logger_xxxx]這樣的形式
# [logger_xxxx] logger_模塊名稱
# level 級別,級別有DEBUG、INFO、WARNING、ERROR、CRITICAL
# handlers 處理類,可以有多個,用逗號分開
# qualname logger名稱,應用程序通過 logging.getLogger獲取。對於不能獲取的名稱,則記錄到root模塊。
# propagate 是否繼承父類的log信息,0:否 1:是
[handler_infohandler]
# [handler_xxxx]
# class handler類名
# level 日志級別
# formatter,上面定義的formatter
# args handler初始化函數參數
# 實現上面定義的logger模塊,必需是[logger_xxxx]這樣的形式
# [logger_xxxx] logger_模塊名稱
# level 級別,級別有DEBUG、INFO、WARNING、ERROR、CRITICAL
# handlers 處理類,可以有多個,用逗號分開
# qualname logger名稱,應用程序通過 logging.getLogger獲取。對於不能獲取的名稱,則記錄到root模塊。
# propagate 是否繼承父類的log信息,0:否 1:是
[handler_infohandler]
# [handler_xxxx]
# class handler類名
# level 日志級別
# formatter,上面定義的formatter
# args handler初始化函數參數
[formatter_form01]
# 日志格式
#--------------------------------------------------
# %(asctime)s 年-月-日 時-分-秒,毫秒 2013-04-26 20:10:43,745
# %(filename)s 文件名,不含目錄
# %(pathname)s 目錄名,完整路徑
# %(funcName)s 函數名
# %(levelname)s 級別名
# %(lineno)d 行號
# %(module)s 模塊名
# %(message)s 消息體
# %(name)s 日志模塊名
# %(process)d 進程id
# %(processName)s 進程名
# %(thread)d 線程id
# %(threadName)s 線程名
使用方式:
from logging.config import fileConfig
fileConfig('loggin_config.ini')
logger=logging.getLogger('infoLogger')
logger.info('test1')
logger_error=logging.getLogger('errorhandler')
logger_error.error('test5')