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

[经验分享] PyCon 2011

[复制链接]

尚未签到

发表于 2017-5-8 11:02:08 | 显示全部楼层 |阅读模式

  
本作品采用知识共享署名-非商业性使用-相同方式共享 3.0 Unported许可协议进行许可。允许非商业转载,但应注明作者及出处。

  

作者:liuyuan_jq

  
2011-03-30

创建日志对象
  # 创建一个日志对象,可以带一个名字,可以缺省root_logger = logging.getLogger('')
设置日志级别
  # 设置日志级别,小于指定级别的信息被忽略,缺省: logging.WARNINGroot_logger.setLevel(logging.DEBUG)
创建控制台日志处理器
  # 创建一个Handler日志处理器console = logging.StreamHandler(sys.stderr)console_format = '%(message)s'# 创建一个日志格式器,规范日志的输出格式,缺省为:%(messages)s# 将格式器绑定到处理器上console.setFormatter(logging.Formatter(console_format))# 设置控制台显示级别console.setLevel(logging.INFO) # TODO: command line switch# 将处理器绑定到日志对象上root_logger.addHandler(console)
创建文件日志处理器
  # RotatingFileHandler 发送信息到磁盘文件,并且限制最大的日志文件大小,并适时轮徇file_handler = logging.handlers.RotatingFileHandler('logging_example.log', # use a full path)file_format = '%(asctime)s %(levelname)6s %(name)s %(message)s'file_handler.setFormatter(logging.Formatter(file_format))file_handler.setLevel(logging.DEBUG)root_logger.addHandler(file_handler)
发送日志
  ################################################################################# 返回一个logger,可以指定名字,如果没有指定名字则返回根logger。# 指定的名字典型的为以点分隔的分层次的名字。# 选择一个恰当的名字,让别人知道,谁在输出日志。# 所有使用相同名字调用这个函数都会返回相同的logger实例。#这意味着logger实例不需要在应用中到处传递。################################################################################# Log sample messages with different levelslog = logging.getLogger(__name__)log.info('on the console and in the file')log.debug('only in the file')log.error('simple error message')
运行结果
  ################################################################################# 结果# logging_example.log#   2011-03-30 10:17:40,104   INFO __main__ on the console and in the file#   2011-03-30 10:17:40,105  DEBUG __main__ only in the file#   2011-03-30 10:17:40,105  ERROR __main__ simple error message#   2011-03-30 10:17:40,106  ERROR __main__ failure message# console#   on the console and in the file#   simple error message#   failure message################################################################################
完整代码
  #!/usr/bin/env python# encoding: utf-8"""Sending log output to a file and the console at the same time."""import loggingimport logging.handlersimport sys# Log verbosely# 创建一个日志对象,可以带一个名字,可以缺省root_logger = logging.getLogger('')# 设置日志级别,小于指定级别的信息被忽略,缺省: logging.WARNINGroot_logger.setLevel(logging.DEBUG)################################################################################# Set up console output to stderr# 创建一个Handler日志处理器console = logging.StreamHandler(sys.stderr)console_format = '%(message)s'# 创建一个日志格式器,规范日志的输出格式,缺省为:%(messages)s# 将格式器绑定到处理器上console.setFormatter(logging.Formatter(console_format))# 设置控制台显示级别console.setLevel(logging.INFO) # TODO: command line switch# 将处理器绑定到日志对象上root_logger.addHandler(console)################################################################################# Include debug messages when logging to a file# RotatingFileHandler 发送信息到磁盘文件,并且限制最大的日志文件大小,并适时轮徇file_handler = logging.handlers.RotatingFileHandler('logging_example.log', # use a full path)file_format = '%(asctime)s %(levelname)6s %(name)s %(message)s'file_handler.setFormatter(logging.Formatter(file_format))file_handler.setLevel(logging.DEBUG)root_logger.addHandler(file_handler)################################################################################# 返回一个logger,可以指定名字,如果没有指定名字则返回根logger。# 指定的名字典型的为以点分隔的分层次的名字。# 选择一个恰当的名字,让别人知道,谁在输出日志。# 所有使用相同名字调用这个函数都会返回相同的logger实例。#这意味着logger实例不需要在应用中到处传递。################################################################################# Log sample messages with different levelslog = logging.getLogger(__name__)log.info('on the console and in the file')log.debug('only in the file')log.error('simple error message')# Replace excepthook with loggerdef log_exception(exc_type, exc_value, traceback):logging.getLogger(__name__).error(exc_value)sys.excepthook = log_exception# Send exceptions to the logger automaticallyraise RuntimeError('failure message')################################################################################# 结果# logging_example.log#   2011-03-30 10:17:40,104   INFO __main__ on the console and in the file#   2011-03-30 10:17:40,105  DEBUG __main__ only in the file#   2011-03-30 10:17:40,105  ERROR __main__ simple error message#   2011-03-30 10:17:40,106  ERROR __main__ failure message# console#   on the console and in the file#   simple error message#   failure message################################################################################
  


运维网声明 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-374600-1-1.html 上篇帖子: python的音乐本地搜索统计的小工具(速度优化版) 下篇帖子: [Python]网络爬虫(三):异常的处理和HTTP状态码的分类
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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