logging模板日志格式
創建loginfo.py模塊,然后導入定義的logging配置,即可使用
cat loginfo.py
"""
logging配置
"""
import os
import logging.config
import datetime
import time
# 定義三種日志輸出格式 開始
standard_format = '[%(asctime)s][%(threadName)s:%(thread)d][task_id:%(name)s][%(filename)s:%(lineno)d]' \
'[%(levelname)s][%(message)s]' #其中name為getlogger指定的名字
simple_format = '[%(levelname)s][%(asctime)s][%(filename)s:%(lineno)d]%(message)s'
id_simple_format = '[%(levelname)s][%(asctime)s] %(message)s'
# 定義日志輸出格式 結束
logfile_dir = os.path.dirname(os.path.abspath(__file__)) # log文件的目錄
date_time = str(datetime.date.fromtimestamp(time.time()))
logfile_name = 'access'+date_time+'.log' # log文件名
# 如果不存在定義的日志目錄就創建一個
if not os.path.isdir(logfile_dir):
os.mkdir(logfile_dir)
# log文件的全路徑
logfile_path = os.path.join(logfile_dir, logfile_name)
# log配置字典
LOGGING_DIC = {
'version': 1,
'disable_existing_loggers': False,
'formatters': {
'standard': {
'format': standard_format
},
'simple': {
'format': simple_format
},
},
'filters': {},
'handlers': {
#打印到終端的日志
'console': {
'level': 'DEBUG',
'class': 'logging.StreamHandler', # 打印到屏幕
'formatter': 'simple'
},
#打印到文件的日志,收集info及以上的日志
'default': {
'level': 'DEBUG',
# 'class': 'logging.handlers.RotatingFileHandler', # 保存到文件
"class": "logging.handlers.TimedRotatingFileHandler", # 依照時間進行切割
'formatter': 'standard',
'filename': logfile_path, # 日志文件
# 'maxBytes': 1024*1024*5, # 日志大小 5M
"when": "h", # 小時格式
"interval": 24, # 24 小時
'backupCount': 7, # 7個
'encoding': 'utf-8', # 日志文件的編碼,再也不用擔心中文log亂碼了
},
},
'loggers': {
'': {
'handlers': ['default', 'console'], # 這里把上面定義的兩個handler都加上,即log數據既寫入文件又打印到屏幕
'level': 'DEBUG',
},
},
}
def load_my_logging_cfg():
logging.config.dictConfig(LOGGING_DIC) # 導入上面定義的logging配置
if __name__ == '__main__':
load_my_logging_cfg()
引用方法:
import logging
import loginfo # 導入自定義的loginfo 格式
loginfo.load_my_logging_cfg()
logger1 = logging.getLogger(__name__)
logger2 = logging.getLogger("collect")
logger1.debug("默認日志的debug")
logger1.info("默認日志的info")