设为首页 收藏本站
查看: 762|回复: 0

[经验分享] 记录一下自己用到的python logging

[复制链接]

尚未签到

发表于 2015-12-1 10:38:24 | 显示全部楼层 |阅读模式
  最近想把自己零零散散写的代码嵌成一个应用,要考虑到各方面的debug,把logging看了一下,把用到的记下来。


  • 将日志打印到屏幕



import logging
logging.debug(u'调试')
logging.info(u'运行')
logging.warning(u'警告')
#运行显示:
#WARNING:root:警告
#默认情况下,logging打印WARNING级别以上的,并打印到屏幕。
#日志级别大小关系 CRITICAL > ERROR > WARNING > INFO > DEBUG > NOTSET(默认),并且可以自定义。

  • basicConfig函数配置日志输出



#-*- coding:utf-8 -*-
import logging
logging.basicConfig(level=logging.DEBUG,
format=u'%(asctime)s 文件:%(filename)s [第 %(lineno)d 行] 等级: %(levelname)s 信息: %(message)s',
datefmt=' %Y %b %d  %H:%M:%S,%a',
filename='guapeng.log',
filemode='w')
logging.debug(u'调试')
logging.info(u'信息')
logging.warning(u'警告')
#guapeng.log文件显示如下
#2015 Jul 27 16:22:26,Mon 文件:testlog.py [第 10 行] 等级: DEBUG 信息: 调试
#2015 Jul 27 16:22:26,Mon 文件:testlog.py [第 11 行] 等级: INFO 信息: 信息
#2015 Jul 27 16:22:26,Mon 文件:testlog.py [第 12 行] 等级: WARNING 信息: 警告
#basicConfig参数说明:
#filename: 指定日志文件名
#filemode: 打开模式,'w'或'a'
#format: 指定输出的格式和内容,一些format默认的参数:
#  %(levelno)s: 日志级别数值
#  %(levelname)s: 日志级别名称
#  %(pathname)s: 当前执行程序的路径,相当于sys.argv[0]
#  %(filename)s: 当前执行程序名(注意这里与log文件名是不同的)
#  %(funcName)s: 当前执行函数
#  %(lineno)d: 当前行号
#  %(asctime)s: 当前时间
#  %(thread)d: 线程ID
#  %(threadName)s: 线程名称
#  %(process)d: 进程ID
#  %(message)s: 日志信息
#datefmt: 指定时间格式,与time.strftime()一样
#level: 设置打印日志级别,默认为logging.WARNING,上例为DEBUG,故大于DEBUG的都输出到log文件。
#stream: 指定日志的输出方式,默认输出到sys.stderr(屏幕),当stream和filename同时指定时,stream被忽略

  • 将debug信息打印打log文件,将info信息打印到屏幕



#-*- coding:utf-8 -*-
import logging
logging.basicConfig(level=logging.DEBUG,
format=u'%(asctime)s 文件:%(filename)s [第 %(lineno)d 行] 等级: %(levelname)s 信息: %(message)s',
datefmt=' %Y %b %d  %H:%M:%S,%a',
filename='guapeng.log',
filemode='w')
#定义一个StreamHandler,将INFO级别的信息打印到屏幕
console = logging.StreamHandler()
console.setLevel(logging.INFO)
formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
console.setFormatter(formatter)
log = logging.getLogger('').addHandler(console)

logging.debug(u'调试')
logging.info(u'信息')
logging.warning(u'警告')
#guapeng.log文件显示如下
#2015 Jul 27 16:22:26,Mon 文件:testlog.py [第 10 行] 等级: DEBUG 信息: 调试
#2015 Jul 27 16:22:26,Mon 文件:testlog.py [第 11 行] 等级: INFO 信息: 信息
#2015 Jul 27 16:22:26,Mon 文件:testlog.py [第 12 行] 等级: WARNING 信息: 警告
#屏幕显示如下
#root        : INFO    信息
#root        : WARNING 警告

  • 用config文件,同时实现日志文件按天存储,而且只存一周内的日志。
  python代码



#-*- coding:utf-8 -*-
import logging
import logging.config
#导入配置文件
logging.config.fileConfig("logging.conf")
#创建logger
loggerInfo = logging.getLogger("TimeInfoLogger")
#测试代码
loggerInfo.debug("debug message")
loggerInfo.info("info message")
loggerInfo.warn("warn message")
loggerInfo.error("error message")
loggerInfo.critical("critical message")
  logging.conf文件代码



# 定义logger模块,root是父类,必需存在的,其它类自行定义。
[loggers]
keys=root,TimeInfoLogger
# 定义handler
[handlers]
keys=TimeInfoHandler
#定义输出格式
[formatters]
keys=TimeInfoFmt
#--------------------------------------------------
# 实现上面定义的logger模块,必需是[logger_xxxx]这样的形式
#--------------------------------------------------
# [logger_xxxx] logger_模块名称
# level     级别,级别有DEBUG、INFO、WARNING、ERROR、CRITICAL
# handlers  处理类,可以有多个,用逗号分开
# qualname  logger名称,应用程序通过 logging.getLogger获取。对于不能获取的名称,则记录到root模块。
# propagate 是否继承父类的log信息,0:否 1:是
[logger_root]
level=INFO
handlers=TimeInfoHandler
[logger_TimeInfoLogger]
level=INFO
handlers=TimeInfoHandler
propagate=0
qualname=TimeInfoLogger
#--------------------------------------------------
# handler
#--------------------------------------------------
# [handler_xxxx]
# class handler类名
# level 日志级别
# formatter,上面定义的formatter
# args handler初始化函数参数
[handler_TimeInfoHandler]
class=logging.handlers.TimedRotatingFileHandler
level=INFO
formatter=TimeInfoFmt
args=('C:\\Users\\tyanf\\Desktop\\error.log', 'midnight', 1, 6)
#--------------------------------------------------
# 日志格式
#--------------------------------------------------
# %(asctime)s       年-月-日 时-分-秒,毫秒 2013-04-26 20:10:43,745
# %(filename)s      文件名,不含目录
# %(pathname)s      目录名,完整路径
# %(funcName)s      函数名
# %(levelname)s     级别名
# %(lineno)d        行号
# %(module)s        模块名
# %(message)s       消息体
# %(name)s          日志模块名
# %(process)d       进程id
# %(processName)s   进程名
# %(thread)d        线程id
# %(threadName)s    线程名
[formatter_TimeInfoFmt]
format=%(asctime)s %(levelname)s %(message)s
datefmt=
class=logging.Formatter


#测试时间从7月20日到7月27号,最后文件库显示如下:
#error.log.2015-07-21
#error.log.2015-07-22
#error.log.2015-07-23
#error.log.2015-07-24
#error.log.2015-07-25
#error.log.2015-07-26
#error.log
#其中error.log.2015-07-20由于程序设定backupcount为6,当大于6时把最早的删除,再添加新的日志文件,故已经被删除。
  参考资料:
  http://my.oschina.net/leejun2005/blog/126713
  https://docs.python.org/2/library/logging.handlers.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-145771-1-1.html 上篇帖子: [Python 3.x 官方文档翻译]The Python Tutorial Python教程 下篇帖子: Python 的命令行参数处理 optparse->argparse
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表