python3--logging模块

logging模块用于日志相关操作。详参https://docs.python.org/3.7/library/

一、直接使用logging

通过basicConfig参数设置输出日志内容的格式、日志级别等信息。

basicConfig参数说明
参数名参数说明
filename指定日志存储文件
filemode指定日志写入方式,在指定了filename时使用这个参数,默认值为“a”--追加,可指定为“w”
format指定日志显示格式
datefmt指定日期时间格式https://mp.csdn.net/postedit/90639025
level设置日志级别,日志级别等级CRITICAL> ERROR > WARNING > INFO > DEBUG
stream用指定的stream创建StreamHandler。可以指定输出到sys.stderr,sys.stdout或者文件,默认为sys.stderr。若同时列出了filename和stream两个参数,则stream参数会被忽略。
basicConfig中参数format格式化串说明
格式化串说明
%(asctime)s字符串形式的当前时间。默认格式是 '2019-06-13 16:55:36,537'。最后三位是毫秒。可使用datefmt参数格式化日期。
%(name)sLogger的名字,getLogger可查看
%(levelno)s数字形式的日志级别
%(levelname)s 文本形式的日志级别
%(pathname)s日志输出所在模块完整路径名
%(filename)s日志输出所在模块文件名
%(module)s日志输出所在模块名
%(funcName)s日志输出所在函数名
%(lineno)d日志输出语句所在的代码行
%(created)f当前时间,UNIX表示时间的浮点数
%(relativeCreated)d自Logger创建以来到输出日志信息时的毫秒数
%(thread)d线程ID
%(process)d进程ID
%(message)s用户输出的消息

1.在控制台输出日志信息

import logging
sh = logging.StreamHandler()
logging.basicConfig(
    format='%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s',
    datefmt='%Y-%m-%d %H:%M:%S %p',
    handlers=[sh],
    level=logging.INFO
)
logging.info('没错吧')   # 控制台输出  2019-06-14 15:35:51 PM - root - INFO -testlogging:  没错吧

2.在指定文件中存储日志信息,不切分日志

import logging
fh = logging.FileHandler(filename='test.log', encoding='utf-8')
logging.basicConfig(    # 指定日志输出格式及内容
    format='%(asctime)s - %(name)s - %(levelno)s - %(levelname)s - %(filename)s - %(message)s',
    datefmt='%Y-%m-%d %H:%M:%S %p',
    handlers=[fh],
    level=logging.ERROR
)
logging.error("错误信息")
# test.log文件中存储内容 2019-06-14 11:21:53 AM - root - 40 - ERROR - testlogging.py - 错误信息
print(logging.getLogger())   # <RootLogger root (ERROR)>

3.在指定文件中存储日志信息,切分日志

  • 按照存储文件大小切分
import time
import logging
from logging import handlers

# 日志存放在app.log文件,如果日志内容超过maxBytes设定的最大值,则将app.log文件重命名为app.log.1,
# 后续生成的日志文件依旧存放在app.log文件中,如果又超过设置的最大值,将app.log.1重命名为app.log.2,app.log文件重命名为app.log.1,
# 后续生成的日志文件依旧存放在app.log文件中,如果又超过设置的最大值,将app.log.2重命名为app.log.3,app.log.1重命名为app.log.2,app.log文件重命名为app.log.1,
# 后续生成的日志文件依旧存放在app.log文件中,如果又超过设置的最大值,将app.log.3重命名为app.log.4,app.log.2重命名为app.log.3,app.log.1重命名为app.log.2,app.log文件重命名为app.log.1,
# 后续生成的日志文件依旧存放在app.log文件中,如果又超过设置的最大值,将app.log.4重命名为app.log.5,app.log.3重命名为app.log.4,app.log.2重命名为app.log.3,app.log.1重命名为app.log.2,app.log文件重命名为app.log.1。
# backupCount=5设定备份文件数为5个
# 当超过备份文件能够存储的大小时,之前的内容将丢失,重复下面的操作:
# 后续生成的日志文件依旧存放在app.log文件中,如果又超过设置的最大值,将app.log.4重命名为app.log.5,app.log.3重命名为app.log.4,app.log.2重命名为app.log.3,app.log.1重命名为app.log.2,app.log文件重命名为app.log.1。
rh = handlers.RotatingFileHandler('app.log', maxBytes=1024,backupCount=5,encoding='utf-8')   

logging.basicConfig(
    format='%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s',
    datefmt='%Y-%m-%d %H:%M:%S',
    handlers=[rh],
    level=logging.ERROR
)
  
for i in range(1,1000):
    time.sleep(1)
    logging.error('这是第{}行错误'.format(i))
  • 按照时间切分
import time
import logging
from logging import handlers 
# 日志文件存放在timeapp.log中,when参数设置备份时间单位s为秒,interval为备份间隔,此处为10s备份一次,
# 每10秒将timeapp.log重命名为timeapp.log.%Y-%m-%d_%H-%M-%S
# backupCount=5为设置备份文件个数,超过5个备份文件时,之前的备份文件被删除,使用默认值时,不会删除备份文件。
# when的取值: S秒\M分\H时
#             D天  
#            'W0'-'W6' 周一至周日
#            'midnight'午夜
th = handlers.TimedRotatingFileHandler(filename='timeapp.log', when='S', interval=10, encoding='utf-8',backupCount=5)  # 按时间切分日志
logging.basicConfig(
    format='%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s',
    datefmt='%Y-%m-%d %H:%M:%S',
    handlers=[th],
    level=logging.ERROR
)
   
for i in range(1,1000):
    time.sleep(1)
    logging.error('这是第{}行错误'.format(i))

4.控制台及文件中都显示日志

import logging
fh = logging.FileHandler(filename='test.log', encoding='utf-8')
sh = logging.StreamHandler()
logging.basicConfig(
    format='%(asctime)s - %(name)s - %(levelno)s - %(levelname)s - %(filename)s - %(message)s',
    datefmt='%Y-%m-%d %H:%M:%S %p',
    handlers=[fh,sh],    # 多个handler
    level=logging.ERROR
)
logging.error("错误信息")

二、使用Logger对象

import time
import logging
logger = logging.getLogger('testLogger')  # 可设置Logger的名称
# 将日志写入文件中
fh = logging.FileHandler('testLogger.log',encoding='utf-8') 
# logging.Formatter与logging.basicConfig中format参数作用相同
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
formatter.datefmt='%Y-%m-%d %H:%M:%S %p'   # 设置日期格式
fh.setFormatter(formatter) 
# logger.addHandler与logging.basicConfig中handlers参数作用类似
logger.addHandler(fh)   # 可添加多个
# logger.setLevel与logging.basicConfig中level参数作用相同
logger.setLevel(logging.CRITICAL)  # 设置日志级别
for i in range(1,1000):
    time.sleep(1)
    logger.critical('这是第{}行错误'.format(i))

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值