博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python 中关于logging 日志的输出设定
阅读量:6436 次
发布时间:2019-06-23

本文共 1299 字,大约阅读时间需要 4 分钟。

hot3.png

  1. #!/usr/bin/python  
  2. # coding: utf-8  
  3.    
  4. import logging  
  5. import logging.handlers  
  6. from logging import *  
  7. from datetime import *  
  8.   
  9. logger = logging.getLogger()  
  10. logger.setLevel(logging.DEBUG)  
  11.   
  12. rht = logging.handlers.TimedRotatingFileHandler("reindex_out.log", 'D')  
  13. fmt = logging.Formatter("%(asctime)s %(pathname)s %(filename)s %(funcName)s %(lineno)s \  
  14.      %(levelname)s - %(message)s", "%Y-%m-%d %H:%M:%S")  
  15. rht.setFormatter(fmt)  
  16. logger.addHandler(rht)  
  17.   
  18. debug = logger.debug  
  19. info = logger.info  
  20. warning = logger.warn  
  21. error = logger.error  
  22. critical = logger.critical  

 

  1. #!/usr/bin/env python  
  2. # coding utf-8  
  3.    
  4. from logger import *  
  5. import sys  
  6. import os  
  7.    
  8. info("log from logger info")  
  9.   
  10. debug("this is from test.py")  
  11. print 'current dir is ' + os.getcwd()

 format: 指定输出的格式和内容,format可以输出很多有用信息,如上例所示:

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

datefmt: 指定时间格式,同time.strftime()

level: 设置日志级别,默认为logging.WARNING

 

级别 对应的值
CRITICAL 50
ERROR 40
WARNING 30
INFO 20
DEBUG 10
NOTSET 0

 

可以给日志对象(Logger Instance)设置日志级别,低于该级别的日志消息将会被忽略,也可以给Hanlder设置日志级别,对于低于该级别的日志消息, Handler也会忽略。

 

转载于:https://my.oschina.net/u/3643685/blog/1823336

你可能感兴趣的文章
解决win10不能安装NVIDIA的RTX 20系列的显卡驱动问题
查看>>
pdf如何解密
查看>>
jquery datatable的详细用法
查看>>
并发编程之 进程
查看>>
ansible 下lineinfile详细使用
查看>>
oracle 用函数返回对象集合
查看>>
猫猫学IOS(二十一)UIApplication设置程序图标右上⾓红⾊数字_联⺴指⽰器等
查看>>
Java(第十五章)
查看>>
Android--静默安装
查看>>
生命有尽,大道无涯
查看>>
JavaScript实现省市二级联动
查看>>
IOS Unit test
查看>>
HttpClient 学习整理[转]
查看>>
2019-05-21 Java学习日记之String类型Demo
查看>>
PHP将两个二维数组合并为一个二维数组的方法
查看>>
再见,2014;你好2015
查看>>
mysql 导入导出.sql文件
查看>>
NIO - Selector源码分析
查看>>
Java简单的数组用法尝试,和C语言很不一样
查看>>
linux-Centos7安装python3并与python2共存
查看>>