日志是用来记录程序在运行过程中发生的状况,在程序开发过程中添加日志模块能够帮助我们了解程序运行过程中发生了哪些事件,这些事件也有轻重之分。
根据事件的轻重可分为以下几个级别:
DEBUG: 详细信息,通常仅在诊断问题时才受到关注。整数level=10
INFO: 确认程序按预期工作。整数level=20
WARNING:出现了异常,但是不影响正常工作.整数level=30
ERROR:由于某些原因,程序 不能执行某些功能。整数level=40
CRITICAL:严重的错误,导致程序不能运行。整数level=50
默认的级别是WARNING,也就意味着只有级别大于等于的才会被看到,跟踪日志的方式可以是写入到文件中,也可以直接输出到控制台。
输出到控制台
下面是一个小例子通过将日志输出到控制台的方法:
import logging logging.warning('Watch out!') # 将输出到控制台 logging.info('I told you so') # 不会输出 logging.error("an error occurrence!") #将输出到控制台
输出结果
WARNING:root:Watch out! ERROR:root:an error occurrence
输出到文件中
新开一个python解释器,确保不是上面代码的session
import logging logging.basicConfig(filename='example.log',level=logging.DEBUG) logging.debug('This message should go to the log file') logging.info('So should this') logging.warning('And this, too')
这个时候控制台上面就没有了输出,文件example.log中的内容
DEBUG:root:This message should go to the log file INFO:root:So should this WARNING:root:And this, too
假定需要手动调整日志的级别,我们可以在命令行以参数的形式传入--log=INFO,在代码中可以采用下面的处理方式
# 输入参数 --log=DEBUG or --log=debug numeric_level = getattr(logging, loglevel.upper(), None)#返回10,否则None if not isinstance(numeric_level, int): raise ValueError('Invalid log level: %s' % loglevel) logging.basicConfig(level=numeric_level, ...)
变量的日志
使用格式化字符串的方式,为变量添加日志
import logging logging.warning('%s before you %s', 'Look', 'leap!')
自定义日志格式
我们还可以根据我们的需求自定义输出模板
import logging logging.basicConfig(format='%(asctime)s: %(levelname)s: %(message)s',level=logging.DEBUG) logging.debug('This message should appear on the console') logging.info('So should this') logging.warning('And this, too')
输出
2017-10-24 14:03:53,671: DEBUG: This message should appear on the console 2017-10-24 14:03:53,690: INFO: So should this 2017-10-24 14:03:53,694: WARNING: And this, too
内部实际传入的为一个字典,%(key)为字典的key。
上面是python logging模块的一些基本用法, 已经能够满足我们的许多需求,下面简单介绍下logging的一些高级用法。在logging模块中主要包括logger,handlers,filter,formatters,这几个组件
logger:提供了应用接口,供程序使用
handlers:用来将logger创建的log 发送到相应的目的地
filter:为要输出的日志提供了更细粒度的设置
formatters:设置最终的输出格式
下面是这几个组件配合使用的例子
import logging logger = logging.getLogger('logger_name')# 创建logger对象 logger.setLevel(logging.DEBUG) handler = logging.StreamHandler()# 创建 console handler 并设置级别为debug handler.setLevel(logging.DEBUG) formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')# 创建输出格式 handler.setFormatter(formatter)# 为handler添加fromatter logger.addHandler(handler)# 将handler添加到 logger logger.debug('debug message')# 'application' code logger.info('info message') logger.warn('warn message') logger.error('error message') logger.critical('critical message')
输出结果:
2017-10-24 16:50:43,127 - logger_name - DEBUG - debug message
2017-10-24 16:50:43,138 - logger_name - INFO - info message
2017-10-24 16:50:43,141 - logger_name - WARNING - warn message
2017-10-24 16:50:43,144 - logger_name - ERROR - error message
2017-10-24 16:50:43,148 - logger_name - CRITICAL - critical message
小应用案例
下面是自己定义的一个日志处理方法,既能够写入到文件中(滚动保存近15天的日志,日志格式app.log, app.log.1, app.log.2),又能输出到控制台。
import logging from logging.handlers import TimedRotatingFileHandler class MylogHandler(logging.Logger): def __init__(self,name,level="DEBUG",stream=True,files=True): self.name = name self.level = level logging.Logger.__init__(self,self.name,level=self.level) if stream: self.__streamHandler__(self.level) if files: self.__filesHandler__(self.level) def __streamHandler__(self,level=None): handler = TimedRotatingFileHandler(filename=self.name+".log", when='D', interval=1, backupCount=15) handler.suffix = '%Y%m%d.log' handler.setLevel(level) formatter = logging.Formatter('%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s') handler.setFormatter(formatter) self.addHandler(handler) #将hander添加到logger上 def __filesHandler__(self,level=None): handler = logging.StreamHandler() formatter = logging.Formatter('%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s') handler.setFormatter(formatter) handler.setLevel(level) self.addHandler(handler) if __name__ == '__main__': log = MylogHandler('test') log.info('this is a my log handler')
总结
以上所述是小编给大家介绍的python中 logging的使用详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]