python 中关于logging 日志的输出设定

本文详细介绍了Python中日志模块的使用方法,包括如何设置不同级别的日志输出、配置文件输出格式以及使用TimedRotatingFileHandler实现日志文件按时间轮转等功能。
  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

 

级别对应的值
CRITICAL50
ERROR40
WARNING30
INFO20
DEBUG10
NOTSET0

 

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

 

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值