首页 > 编程语言 >python学习之 logging包

python学习之 logging包

时间:2023-02-07 15:13:07浏览次数:45  
标签:logging 05 python 30 学习 2019 logger message

1,logging包

python的一个包,专门用来写日志的。

官方一共划分了6个等级的log类型,分别对应重要性等级50,40,30,20,10,0:

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

2,logging打印日志到控制台(和print效果差不多)

废话不说,直接看代码:

复制代码
#!coding=utf-8
import logging

logging.basicConfig(level=logging.DEBUG, datefmt='%Y/%m/%d %H:%M:%S',format='%(asctime)s : %(name)s : %(levelname)s : %(message)s')
logger = logging.getLogger("daqing")    #把设置读取到实例中才能用哦

logging.debug('this is the debug message')
logging.info('this is the info message')
logging.warning('this is the warning message')
logging.error('this is the error message')
logging.critical('this is the critical message')
复制代码 复制代码
#返回的结果:
2019/05/30 13:21:46 : root : DEBUG : this is the debug message
2019/05/30 13:21:46 : root : INFO : this is the info message
2019/05/30 13:21:46 : root : WARNING : this is the warning message
2019/05/30 13:21:46 : root : ERROR : this is the error message
2019/05/30 13:21:46 : root : CRITICAL : this is the critical message
复制代码

比较重要的是bascConfig函数,它必须在一开始就进行定义,它的几个参数如下
    # level用于指定最低等级的logging输出,高于或者等于这个等级自动输出,
    # format是指定了字符串格式:包括 asctime、name、levelname、message四个内容(还有别的),分别代表运行时间、模块名称、日志级别、日志内容。
    #datefomt是用于格式化时间
    #filename指定日志文件的名字,这个例子没有带
    #filemode "w"表示清空并且写入,“a"表示追加,一般和上一个参数一块用
    #style 用于指定format的占位符,必须在format前定义,只能是%,{或者$

3,打印日志到文档

复制代码
#!coding=utf-8
import logging

logging.basicConfig(level=logging.DEBUG,
                    filename='output.log',
                    datefmt='%Y/%m/%d %H:%M:%S',
                    format='%(asctime)s : %(name)s : %(module)s : %(process)d :  %(message)s')  
logger = logging.getLogger("daqing")    #此处logger和logging还是有区别的,logger写出的日志显示的name一项是daqing,而logging显示的name是root
logger.debug('this is the debug message')
logger.info('this is the info message')
logger.warning('this is the warning message')
logging.error('this is the error message')
logging.critical('this is the critical message')
复制代码 复制代码
#定义的format是这样的:%(asctime)s : %(name)s : %(module)s : %(process)d :  %(message)s
#返回到output.log中的内容:
2019/05/30 13:23:18 : root : logtest : 4928 :  this is the debug message
2019/05/30 13:23:18 : root : logtest : 4928 :  this is the info message
2019/05/30 13:23:18 : root : logtest : 4928 :  this is the warning message
2019/05/30 13:23:18 : root : logtest : 4928 :  this is the error message
2019/05/30 13:23:18 : root : logtest : 4928 :  this is the critical message
复制代码

比较重要的是:format内容(常用):

    #%(levelname)s:打印日志级别的名称
    #%(pathname)s:打印当前执行程序的路径
    #%(funcName)s:打印日志的当前函数
    #%(lineno)d:打印日志的当前行号
    #%(process)d:打印进程ID
    #%(message)s:打印日志信息
    #%(module)s:打印模块名称
    #%(name)s: 用户名称

4,同时把日志打印到控制台和日志文件中

复制代码
#!ccoding=utf-8
import logging

# 第一步,创建一个logger
logger = logging.getLogger("daqing")
logger.setLevel(logging.DEBUG)  # Log等级总开关

# 第二步,创建一个handler,用于写入日志文件,用的是 logging.FileHandler函数,注意它的参数信息
logfile = './logger.txt'
fh = logging.FileHandler(logfile,encoding="utf-8", mode='w')    #mode="a"则是追加
fh.setLevel(logging.INFO)  # 输出到file的log等级的开关

# 第三步,再创建一个handler,用于输出到控制台
ch = logging.StreamHandler()
ch.setLevel(logging.DEBUG)  # 输出到console的log等级的开关

# 第四步,定义handler的输出格式,控制台和输出到文件的handler可以共用
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
fh.setFormatter(formatter)
ch.setFormatter(formatter)

# 第五步,将logger添加到handler里面,这一步是最重要的,本质上就是为logger添加多个handler
logger.addHandler(fh) 
logger.addHandler(ch)

# 日志
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
复制代码 复制代码
#控制台返回的结果是这样的:
2019-05-30 13:31:46,235 - logtest.py[line:70] - DEBUG: this is a logger debug message
2019-05-30 13:31:46,236 - logtest.py[line:71] - INFO: this is a logger info message
2019-05-30 13:31:46,236 - logtest.py[line:72] - WARNING: this is a logger warning message
2019-05-30 13:31:46,236 - logtest.py[line:73] - ERROR: this is a logger error message
2019-05-30 13:31:46,236 - logtest.py[line:74] - CRITICAL: this is a logger critical message

#logger.txt返回的是这样的:
2019-05-30 13:31:46,236 - logtest.py[line:71] - INFO: this is a logger info message
2019-05-30 13:31:46,236 - logtest.py[line:72] - WARNING: this is a logger warning message
2019-05-30 13:31:46,236 - logtest.py[line:73] - ERROR: this is a logger error message
2019-05-30 13:31:46,236 - logtest.py[line:74] - CRITICAL: this is a logger critical message
#两者虽然共用一个format设置,但是level不同。于是。。。
复制代码

5,捕获解释器返回的异常信息

复制代码
#!coding=utf-8
import logging

logging.basicConfig(level=logging.DEBUG, datefmt='%Y/%m/%d %H:%M:%S',format='%(asctime)s : %(name)s : %(levelname)s : %(message)s')
logger = logging.getLogger("daqing")    #把设置读取到实例中才能用哦

logger.info("start")
try:
    a=10/0
except Exception:
    logger.error("hehe",exc_info=True)    #此处打印完“hehe”日志以后,会把try中报错的信息也打印出来
logger.info("finish")
复制代码 复制代码
#返回:
2019/05/30 13:42:32 : daqing : INFO : start
2019/05/30 13:42:32 : daqing : ERROR : hehe
Traceback (most recent call last):
  File "D:/python_test/logtest/logtest.py", line 88, in <module>
    a=10/0
ZeroDivisionError: division by zero
2019/05/30 13:42:32 : daqing : INFO : finish
复制代码

6,logger是可以继承的

复制代码
logging.basicConfig(level=logging.DEBUG, datefmt='%Y/%m/%d %H:%M:%S',format='%(asctime)s : %(name)s : %(levelname)s : %(message)s')
logger = logging.getLogger("daqing")    #把设置读取到实例中才能用哦

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')

child_logger=logging.getLogger("daqing.hehe")    #此处的child_logger继承了名字叫daqing的logger的属性
child_logger.setLevel(level=logging.WARNING)   #继承以后修改了部分属性,把level等级改掉了

child_logger.debug('this is a logger debug message')
child_logger.info('this is a logger info message')
child_logger.warning('this is a logger warning message')
child_logger.error('this is a logger error message')
child_logger.critical('this is a logger critical message')
复制代码 复制代码
#返回的logger
2019/05/30 13:50:17 : daqing : DEBUG : this is a logger debug message
2019/05/30 13:50:17 : daqing : INFO : this is a logger info message
2019/05/30 13:50:17 : daqing : WARNING : this is a logger warning message
2019/05/30 13:50:17 : daqing : ERROR : this is a logger error message
2019/05/30 13:50:17 : daqing : CRITICAL : this is a logger critical message
#返回的child_logger
2019/05/30 13:50:17 : daqing.hehe : WARNING : this is a logger warning message
2019/05/30 13:50:17 : daqing.hehe : ERROR : this is a logger error message
2019/05/30 13:50:17 : daqing.hehe : CRITICAL : this is a logger critical message
复制代码

 

标签:logging,05,python,30,学习,2019,logger,message
From: https://www.cnblogs.com/kn-zheng/p/17098465.html

相关文章

  • 游标的学习和使用
    1.游标的认识和作用1.1什么是游标?游标Cursor是处理数据的一种方法,用来查看或者处理结果集中的数据,游标提供了在结果集中一次一行或者多行向前或向后浏览数据的能力;游......
  • UIScrollView全部API学习。
    交流群:QQ529560119>设定滚定条的样式typedefNS_ENUM(NSInteger,UIScrollViewIndicatorStyle){UIScrollViewIndicatorStyleDefault,//blackwithwhiteborder.......
  • NSSet全部API学习。
    /****************集合(NSSet)和数组(NSArray)有相似之处,都是存储不同的对象的地址,不过NSArray是有序的集合,NSSet是无序的集合,同时NSSet可以保证数据的唯一性,当插入相同的数据时......
  • UIView全部API的学习。
    交流群:QQ529560119>/*********UIView是iOS系统界面元素的基础,所有的界面元素都是集成自它。它本身完全是由CoreAnimation来实现的。它真正的绘图部分,是一个叫CALayer(CoreA......
  • 感知机:补充【统计学习方法】
    点到超平面距离公式的推导过程中学学过二维空间中点到直线的距离公式已知点$P(x_0,y_0)$,直线$Ax+By+C=0$,求点$P$到直线$l$的距离点$P$到直线的距离是点$P$到直线$l$的垂......
  • 10节课带你深入学习 DevOps 工程
       作者:JavinPaul10节课带你深入学习DevOps工程对那些想要涉足DevOps领域的工程师来说,这些多样的课程提供了一个很好的开始DevOps现在真的很热门,对于杰出的工程师......
  • centos7+nginx+uwsgi+python3.7.4+django部署实践
    yuminstallpython3yuminstallpython3-develyum-yinstallgccgcc-c++pip3installuwsgipython3​​manage.py​​runserver10.5.1.65:82uwsgi--iniuwsgi.i......
  • 如何检查文件是否有Python的符号链接
    1、对于python3.4及更高版本,可以使用Path类。frompathlibimportPath#rpdisasymboliclink>>>Path('rdp').is_symlink()True>>>Path('README').is_symlink()False2......
  • 数据采集技术之在Python中Libxml模块安装与使用XPath
    为了使用XPath技术,对爬虫抓取的网页数据进行抽取(如标题、正文等等),之后在Windows下安装libxml2模块(安装后使用的是Libxml模块),该模块含有xpath。准备需要的软件包:Python2.7......
  • python静态web服务器如何实现
    1、编写TCP服务器程序。2、获取浏览器发送的http请求消息数据。3、读取固定的页面数据,将页面数据组装成HTTP响应消息数据并发送给浏览器。4、HTTP响应报文数据发送完成后,关......