时间:2021-05-22
一、logging模块讲解
1.函数:logging.basicConfig()
参数讲解:
(1)level代表高于或者等于这个值时,那么我们才会记录这条日志
(2)filename代表日志会写在这个文件之中,如果没有这个字段则会显示在控制台上
(3)format代表我们的日志显示的格式自定义,如果字段为空,那么默认格式为:level:log_name:content
import loggingLOG_FORMAT = "%(asctime)s======%(levelname)s++++++(message)"logging.basicConfig(filename="log1.txt",level=logging.WARNING,format=LOG_FORMAT)logging.log(logging.INFO,"This is a INFO log")logging.log(logging.ERROR,"This is a ERROR log.")二、logging模块的处理流程
1.四大组件
(1)日志器(Logger):产生日志的一个接口。
(2)处理器(Handler):把产生的日志发送到相应的目的地。
(3)过滤器(Filter):更精细的控制那些日志输出。
(4)格式器(Formatter):对输出的信息进行格式化。
2.Logger
(1)产生一个日志
(2)操作
Logger.setLevel() #设置日志器将会处理的日志消息的最低严重级别Logger.addHandler()Logger.moveHander() #上面两个函数,为该logger对象添加和移除一个handler对象Logger.addFilter()Logger.removeFilter() #上面两个函数,为该logger对象添加和移除一个filter对象Logger.debug: #产生一条debug级别的日志,同理,info,error的日志消息Logger.exception #创建一个类似于Logger.error的日志消息Logger.log() #获取一个明确的日志level参数类型创建一个日志记录(3)如何得到一个logger对象
实例化;logging.getLogger()
3.Handler
(1)把log发送到指定位置
(2)方法
setLevel\setFormat\addFilter\removeFilter
(3)不需要直接使用,Handler是基类
logging.StreamHandler #将日志消息发送到输出到Stream。如std.out,std.err或任何file-like对logging.FileHandler #将日志消息发送到磁盘文件。默认情况下文件大小会无限增长logging.handlers.RotatongFileHandler #将日志消息发送到磁盘文件,并支持日志文件按大小切割logging.handlers.TimeRotatingFileHandler #将日志消息发送到磁盘文件,并支持日志文件按时间切割logging.handlers.HTTPHandler #将日志消息以GET或POST的方式发送到一个指定email地址logging.NullHandler #该Handler实例会忽略error message 通常想被想使用logging的library三、源码
d23_2_logger_usage.py
地址:https://github.com/ruigege66/Python_learning/blob/master/d23_2_logger_usage.py
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Django使用python自带的logging作为日志打印工具。简单介绍下logging。logging是线程安全的,其主要由4部分组成:Logger用户使用
在logging中,Logger'slevel的默认等级为warning所以虽然在handler中setlervel了,Logger'slevel和Handle
如下所示:importlogging#创建一个loggerlogger=logging.getLogger('mylogger')logger.setLevel
python的logging模块python提供了一个日志处理的模块,那就是logging。导入logging模块使用以下命令:importlogginglog
Python内置模块logging管理不同级别log打印和存储,非常方便,从此告别了使用print打桩记录,我们来看下logging的魅力吧importlogg