日志级别

import logging  # 引入logging模块
# 将信息打印到控制台上
logging.debug("debug")
logging.info("info")
logging.warning("warning")
logging.error("error")
logging.critical("critical")

回显:

上面可以看到只有后面三个能打印出来

默认生成的root logger的level是logging.WARNING,低于该级别的就不输出了

级别排序:CRITICAL > ERROR > WARNING > INFO > DEBUG

  1. debug : 打印全部的日志,详细的信息,通常只出现在诊断问题上

  2. info : 打印info,warning,error,critical级别的日志,确认一切按预期运行

  3. warning : 打印warning,error,critical级别的日志,一个迹象表明,一些意想不到的事情发生了,或表明一些问题在不久的将来(例如。磁盘空间低”),这个软件还能按预期工作

  4. error : 打印error,critical级别的日志,更严重的问题,软件没能执行一些功能

  5. critical : 打印critical级别,一个严重的错误,这表明程序本身可能无法继续运行

这时候,如果需要显示低于WARNING级别的内容,可以引入NOTSET级别来显示:

import logging  # 引入logging模块
logging.basicConfig(level=logging.NOTSET)  # 设置日志级别
logging.debug("print all levels log")

回显:

部分名词解释

  1. Logging.Formatter:这个类配置了日志的格式,在里面自定义设置日期和时间,输出日志的时候将会按照设置的格式显示内容。

  2. Logging.Logger:Logger是Logging模块的主体,进行以下三项工作:

    • 为程序提供记录日志的接口
    • 判断日志所处级别,并判断是否要过滤
    • 根据其日志级别将该条日志分发给不同handler
  3. 常用函数有:

    • Logger.setLevel() 设置日志级别
    • Logger.addHandler() 和 Logger.removeHandler() 添加和删除一个Handler
    • Logger.addFilter() 添加一个Filter,过滤作用
    • Logging.Handler:Handler基于日志级别对日志进行分发,如设置为WARNING级别的Handler只会处理WARNING及以上级别的日志。
    • setLevel() 设置级别
    • setFormatter() 设置Formatter

日志输出-控制台

import logging  # 引入logging模块
logging.basicConfig(level=logging.DEBUG,format='%(asctime)s-%(filename)s%(funcName)s(%(lineno)d)[%(thread)d]-[%(levelname)s]%(message)s') # 由于日志基本配置中级别设置为DEBUG,所以一下打印信息将会全部显示在控制台上log=logging.getLogger()log.debug("debug")log.info("info")log.warning("warnign")log.error("error")log.critical("critical")

上面代码通过logging.basicConfig函数进行配置了日志级别和日志内容输出格式;因为级别为DEBUG,所以会将DEBUG级别以上的信息都输出显示再控制台上。

回显:

日志输出-文件

import logging  # 引入logging模块
import os.path
import time
# 第一步,创建一个logger
logger = logging.getLogger()
logger.setLevel(logging.INFO)  # Log等级总开关
# 第二步,创建一个handler,用于写入日志文件
rq = time.strftime('%Y%m%d%H%M', time.localtime(time.time()))
log_path = os.path.dirname(os.getcwd()) + '/Logs/'
log_name = log_path + rq + '.log'
logfile = log_name
fh = logging.FileHandler(logfile, mode='w')
fh.setLevel(logging.DEBUG)  # 输出到file的log等级的开关
# 第三步,定义handler的输出格式
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
fh.setFormatter(formatter)
# 第四步,将logger添加到handler里面
logger.addHandler(fh)
# 日志
logger.debug('this is a logger debug message')
logger.info('this is a logger info message')
logger.warning('this is a logger warning message')
logger.error('this is a logger error message')
logger.critical('this is a logger critical message')

日志输出-控制台和文件

#只要在输入到日志中的第二步和第三步插入一个handler输出到控制台:
#创建一个handler,用于输出到控制台
ch = logging.StreamHandler()
ch.setLevel(logging.WARNING)  # 输出到console的log等级的开关
ch.setFormatter(formatter)
logger.addHandler(ch)

format常用格式说明

%(levelno)s: 打印日志级别的数值
%(levelname)s: 打印日志级别名称
%(pathname)s: 打印当前执行程序的路径,其实就是sys.argv[0]
%(filename)s: 打印当前执行程序名
%(funcName)s: 打印日志的当前函数
%(lineno)d: 打印日志的当前行号
%(asctime)s: 打印日志的时间
%(thread)d: 打印线程ID
%(threadName)s: 打印线程名称
%(process)d: 打印进程ID
%(message)s: 打印日志信息

捕捉异常,用traceback记录

import os.path
import time
import logging
# 创建一个logger
logger = logging.getLogger()
logger.setLevel(logging.INFO)  # Log等级总开关# 创建一个handler,用于写入日志文件
rq = time.strftime('%Y%m%d%H%M', time.localtime(time.time()))
log_path = os.path.dirname(os.getcwd()) + '/Logs/'
log_name = log_path + rq + '.log'
logfile = log_name
fh = logging.FileHandler(logfile, mode='w')
fh.setLevel(logging.DEBUG)  # 输出到file的log等级的开关# 定义handler的输出格式
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
fh.setFormatter(formatter)
logger.addHandler(fh)
# 使用logger.XX来记录错误,这里的"error"可以根据所需要的级别进行修改
try:open('/path/to/does/not/exist', 'rb')
except (SystemExit, KeyboardInterrupt):raise
except Exception, e:logger.error('Failed to open file', exc_info=True)

如果需要将日志不上报错误,仅记录,可以将exc_info=False,回显如下:

日志滚动和过期删除(按时间

#coding:utf-8
import logging
import time
import re
from logging.handlers import TimedRotatingFileHandler
from logging.handlers import RotatingFileHandlerdef backroll():#日志打印格式log_fmt = '%(asctime)s\tFile \"%(filename)s\",line %(lineno)s\t%(levelname)s: %(message)s'formatter = logging.Formatter(log_fmt)#创建TimedRotatingFileHandler对象log_file_handler = TimedRotatingFileHandler(filename="ds_update", when="M", interval=2, backupCount=2)#log_file_handler.suffix = "%Y-%m-%d_%H-%M.log"#log_file_handler.extMatch = re.compile(r"^\d{4}-\d{2}-\d{2}_\d{2}-\d{2}.log$")log_file_handler.setFormatter(formatter)logging.basicConfig(level=logging.INFO)log = logging.getLogger()log.addHandler(log_file_handler)#循环打印日志log_content = "test log"count = 0while count < 30:log.error(log_content)time.sleep(20)count = count + 1log.removeHandler(log_file_handler)if __name__ == "__main__":backroll()

filename:日志文件名的prefix;

when:是一个字符串,用于描述滚动周期的基本单位,字符串的值及意义如下:
“S”: Seconds
“M”: Minutes
“H”: Hours
“D”: Days
“W”: Week day (0=Monday)
“midnight”: Roll over at midnight

interval: 滚动周期,单位有when指定,比如:when=’D’,interval=1,表示每天产生一个日志文件

backupCount: 表示日志文件的保留个数

Python logging详细说明相关推荐

  1. python Logging日志记录模块详解

    写在篇前   logging是Python的一个标准库,其中定义的函数和类为应用程序和库的开发实现了一个灵活的事件日志系统.Python logging 的配置由四个部分组成:Logger.Handl ...

  2. python logging模块使用教程

    格式化配置: logging.basicConfig(level=logging.INFO, format='%(asctime)s %(levelname)s %(filename)s [%(lin ...

  3. python logging 控制其他模块等级_Python常用模块:logging模块介绍

    简单使用 #!/usr/local/bin/python# -*- coding:utf-8 -*-import logginglogging.debug('debug message')loggin ...

  4. python logging默认情况下打印_python logging日志打印过程解析

    一. 基础使用 1.1 logging使用场景 日志是什么?这个不用多解释.百分之九十的程序都需要提供日志功能.Python内置的logging模块,为我们提供了现成的高效好用的日志解决方案.但是,不 ...

  5. python logging模块-写日志、log回滚

    python包/模块,专栏总目录: 1.python自定义模块 2.python模块调用顺序 3.python logging模块 4.python定义跨模块的全局变量 1.logging模块简介 l ...

  6. 关于使用python logging模块的几点总结

    关于使用python logging模块的几点总结 使用python的标准日志模块logging可以非常方便地记录日志.Python日志系统非常丰富.添加结构化或非结构化日志输出到python代码,写 ...

  7. Python LOGGING使用方法

    Python LOGGING使用方法 1. 简介 使用场景 场景 适合使用的方法 在终端输出程序或脚本的使用方法 print 报告一个事件的发生(例如状态的修改) logging.info()或log ...

  8. python logging模块使用

    python logging模块使用 logging模块 日志记录的重要性 在开发过程中,我们可以printf或者Debug来排查问题. 但是在生产环境中(黑盒环境)出现问题,我们并不能知道在运行的环 ...

  9. python logging模块使用_python logging模块使用

    近来再弄一个小项目,已经到收尾阶段了.希望加入写log机制来增加程序出错后的判断分析.尝试使用了python logging模块. #-*- coding:utf-8 -*- importloggin ...

最新文章

  1. linux内核dma内存分配,Linux 4.x 内核空间 DMA 虚拟内存地址
  2. 异步/等待-什么时候返回Task vs void?
  3. python 寻找峰值
  4. 计算机科学与技术专业用英语怎么写,计算机科学与技术专业专业英文简历模板...
  5. 现代谱估计:多窗口谱
  6. alert点击完确定关闭浏览器窗口_关务实操技巧:单一窗口缓存4大清理方法,解决部分退单问题...
  7. Vue学习笔记01:准备开发与调试环境
  8. PHP Yii2 composer环境安装
  9. 程序流程三控制,顺序控制,分支控制,循环控制综合练习题
  10. Silverlight 解谜游戏 之十二 游戏暗示(1)
  11. (转)研究报告:区块链+供应链金融
  12. 几何光学学习笔记(20)- 5.3视场光阑
  13. MyBatis的高频面试题
  14. 海康威视监控推流自建服务器实现网页端无插件1-2秒低延迟实时监控
  15. 微信小程序页面onLoad获取app.js的onLaunch数据(异步获取用户信息)
  16. 计算机的运作流程的个人感想
  17. 基于物联网的环境监控系统设计与实现
  18. LeetCode每日一题(2022/5/31)剑指 Offer II 114. 外星文字典(困难)
  19. 第十六章 快速锁定功能项进行爆破,从而达到跳过网络机制
  20. mysql5.7 删除复制_mysql5.7实现主从复制以及产生问题记录

热门文章

  1. 阅读《Android 从入门到精通》(24)——切换图片
  2. 南京工程学院校园网快捷指令
  3. 海店湾养生专家告诉你:有这5个坏习惯,迟早会生病!
  4. Android模仿iOS iMessages10照片选择器的实现
  5. [go学习笔记.第十一章.项目案例] 2.客户信息管理系统
  6. php实现远程升级,教你如何用php实现LOL数据远程获取
  7. 第十二届_国赛蓝桥杯个人模板_基础篇
  8. 网络相册:Gallery+AsyncTask+URLConnection 实现异步加载网络图片
  9. ajax php setinterval,关于javascript:通过ajax执行完php脚本后如何停止setInterval
  10. 计算机信息处理员ppt,信息处理技术员考试指南.ppt