版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ygdxt/article/details/84451834
在开发过程中,日志是一个避不开的话题,有的时候我们不需要控制台输出过多的信息,甚至不输出,当然,我们可以在控制台设置日志的等级来达到目的,但是,日志的保存,日志格式的重写,这些,就必须用python内建的logging模块来实现了。
封装一个通用的日志脚本
命名为logge.py
,代码如下
import os
import time
import logging
#返回一个logger实例,如果没有指定name,返回root logger。
# 只要name相同,返回的logger实例都是同一个而且只有一个,即name和logger实例是一一对应的。
# 这意味着,无需把logger实例在各个模块中传递。只要知道name,就能得到同一个logger实例。
logger = logging.getLogger('mylogger')
# 设置总日志级别, 也可以给不同的handler设置不同的日志级别
#设置logger的level, level有以下几个级别:
# 级别高低顺序:NOTSET < DEBUG < INFO < WARNING < ERROR < CRITICAL
# 如果把looger的级别设置为INFO, 那么小于INFO级别的日志都不输出, 大于等于INFO级别的日志都输出
logger.setLevel(logging.DEBUG)
# 控制台日志和日志文件使用同一个formatter,formatter用于描述日志的格式
formatter = logging.Formatter(
'%(asctime)s - %(filename)s[line:%(lineno)d] - <%(threadName)s %(thread)d>' +
'- <Process %(process)d> - %(levelname)s: %(message)s'
)
# asctime:日志产生的时间;filename:产生日志的脚本文件名;lineno:该脚本文件哪一行代码产生了日志
# threadName: 当前线程名;thread: 当前进程名;Process进程同thread线程
# levelname: logger的级别;meesage: 具体的日志信息
# 创建Handler, 输出日志到控制台和文件
# 日志文件FileHandler
basedir = os.path.abspath(".") #返回脚本所在的绝对路径
log_dir = os.path.join(basedir, 'logs') # 日志文件所在目录,即‘脚本路径/logs'
if not os.path.isdir(log_dir):
os.mkdir(log_dir)
filename = time.strftime('%Y-%m-%d-%H-%M-%S', time.localtime(time.time())) + '.log' # 日志文件名,以当前时间命名
file_handler = logging.FileHandler(os.path.join(log_dir, filename)) # 创建日志文件handler
file_handler.setFormatter(formatter) # 设置Formatter
file_handler.setLevel(logging.INFO) # 单独设置日志文件的日志级别
# 控制台日志StreamHandler
stream_handler = logging.StreamHandler()
stream_handler.setFormatter(formatter)
# stream_handler.setLevel(logging.INFO) # 单独设置控制台日志的日志级别,注释掉则使用总日志级别
# 将handler添加到logger中
logger.addHandler(file_handler)
logger.addHandler(stream_handler)
代码有详细的注释,有问题欢迎评论。
如何使用
假如我们在test.py
需要用到保存日志,可以这样:
from logger import logger
#从logger.py文件里导入logger变量
for i in range(5):
logger.info("这是第"+str(i+1)+"条日志")
#logger.debug("")
#logger.error("")
控制台打印如下:
…/logs文件夹下也产生了日志文件2018-11-24-19-14-05.log
,其内容如下
over!