日志模块logging

导入模块  import logging
六个个日志等级:
    notset:所有信息
    debug:调试日志
    info:记录程序正常执行的关键信息
    warning:输出警告信息
    error:记录代码错误信息(代码运行出错,但是程序还可以继续执行)
    critical:记录代码最严重的错误,程序运行崩溃无法继续执行

 

import logging

logging.debug('debug')
logging.info('info')
logging.warning('warning')    WARNING:root:warning
logging.error('error')    ERROR:root:error
logging.critical('critical')    CRITICAL:root:critical    # 目前默认的收集器是root,默认收集等级是warning及以上

 日志收集器 
    logging模块默认的日志收集器是root
    需要设置自定义的日志收集器,收集等级

日志输出渠道    需要设置输出日志的等级
    1、输出到控制台
    2、输出到指定文件

import logging

# 第一步,自定义一个日志收集器
my_log = logging.getLogger('jiuba')
my_log.setLevel('DEBUG')  # 设置日志收集器的收集等级,必须全部大写

# 第二步,创建一个输出渠道,第一种输出到控制台
sh = logging.StreamHandler()
sh.setLevel('DEBUG')  # 设置输出渠道的输出等级,必须全部大写
# 第二步,第二种创建一个输出渠道,输出到指定文件
fh = logging.FileHandler(filename='jiuba.log', mode='a', encoding='utf8')  # 必须写文件名,编码格式
fh.setLevel('DEBUG')  # 设置输出渠道的输出等级,必须全部大写

# 第三步,把创建的输出渠道添加到日志收集器上,即两者绑定
my_log.addHandler(sh)    # 输出到控制台与日志收集器绑定
my_log.addHandler(fh)    # 输出到文件与日志收集器绑定

# 第四步,设置日志输出格式
formats = '%(asctime)s - [%(filename)s-->line:%(lineno)d] - %(levelname)s--%(name)s: %(message)s'    # 标准的日志输出格式(去掉%(name)s自定义的日志收集器名字)
mat = logging.Formatter(formats)

# 第五步,日志输出格式与输出渠道绑定
sh.setFormatter(mat)    # 输出到控制台与日志输出格式绑定
fh.setFormatter(mat)    # 输出到文件与日志输出格式绑定

my_log.debug('debug')
my_log.info('info')
my_log.warning('warning')
my_log.error('error')
my_log.critical('critical')

日志轮转
根据文件大小进行轮转

import logging
from logging.handlers import RotatingFileHandler
# 第一步,自定义一个日志收集器
my_log = logging.getLogger('jiuba')
my_log.setLevel('DEBUG')  # 设置日志收集器的收集等级,必须全部大写


# 第二步,创建一个输出渠道,输出到指定文件
fh = RotatingFileHandler(filename='jiubadx.log',    # 根据文件大小进行轮转
                         mode='a',
                         maxBytes=1024*1024*20,    # 最大20MB  1024字节*1024字节
                         backupCount=5,    # 最多保存5个文件   每个文件20M,最多保存5个,最新的日志在最上面
                         encoding='utf8')
fh.setLevel('DEBUG')  # 设置输出渠道的输出等级,必须全部大写
sh = logging.StreamHandler()
sh.setLevel('DEBUG')

# 第三步,把创建的输出渠道添加到日志收集器上,即两者绑定
my_log.addHandler(fh)    # 输出到文件与日志收集器绑定
my_log.addHandler(sh)

# 第四步,设置日志输出格式
formats = '%(asctime)s - [%(filename)s-->line:%(lineno)d] - %(levelname)s--%(name)s: %(message)s'    # 标准的日志输出格式(去掉%(name)s自定义的日志收集器名字)
mat = logging.Formatter(formats)

# 第五步,日志输出格式与输出渠道绑定
fh.setFormatter(mat)    # 输出到文件与日志输出格式绑定
sh.setFormatter(mat)

my_log.debug('debug')
my_log.info('info')
my_log.warning('warning')
my_log.error('error')
my_log.critical('critical')

根据时间进行轮转

import logging
from logging.handlers import TimedRotatingFileHandler
# 第一步,自定义一个日志收集器
my_log = logging.getLogger('jiuba')
my_log.setLevel('DEBUG')  # 设置日志收集器的收集等级,必须全部大写


# 第二步,创建一个输出渠道,输出到指定文件
fh = TimedRotatingFileHandler(filename='jiubatime.log',    # 根据时间进行轮转
                              when='h',    # 按小时,s秒,m分,h时,d天
                              interval=7,    # 每7小时一个文件
                              backupCount=5,    # 最多保存5个文件,最新的在最下面
                              encoding='utf8')
fh.setLevel('DEBUG')  # 设置输出渠道的输出等级,必须全部大写
sh = logging.StreamHandler()
sh.setLevel('DEBUG')

# 第三步,把创建的输出渠道添加到日志收集器上,即两者绑定
my_log.addHandler(fh)    # 输出到文件与日志收集器绑定
my_log.addHandler(sh)

# 第四步,设置日志输出格式
formats = '%(asctime)s - [%(filename)s-->line:%(lineno)d] - %(levelname)s--%(name)s: %(message)s'    # 标准的日志输出格式(去掉%(name)s自定义的日志收集器名字)
mat = logging.Formatter(formats)

# 第五步,日志输出格式与输出渠道绑定
fh.setFormatter(mat)    # 输出到文件与日志输出格式绑定
sh.setFormatter(mat)

my_log.debug('debug')
my_log.info('info')
my_log.warning('warning')
my_log.error('error')
my_log.critical('critical')

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值