python模块-logging的智商上限
logging,故名肆意就是正在进行日志,我艹,这个文化底蕴!
logging是python内置的日志模块,便于日常程序的日志写入和输出
logging共分为5个日志等级,分别是:
debug , info , warning , error , critical (已按等级顺序排列)
其中info是在今后经常应用的日志等级,对于logging来说,默认等级是warning,换句话说就是等于或高于warning等级,才会进行输出,默认warning等级,会输出warning,error,critical等级
代码示例:
# 编辑者:闫龙
import logging
logging.debug("debug")
logging.info("info")#最为常用的输出等级
logging.warning("warning")
logging.error("error")
logging.critical("critical") #打印结果:
# WARNING:root:warning
# ERROR:root:error
# CRITICAL:root:critical
那么对于logging日志输出格式,和logging的等级配置要如何进行呢?
在logging中内置了两种方式进行操作,第一种是basicConfig,第二种是logger
那么这两种方式有什么区别呢?下面逐一解析:
第一种方式,baseConfig:
代码示例:
# 编辑者:闫龙
import logging
logging.basicConfig(
level=logging.DEBUG,#更改日志的默认等级为DEBUG
format="%(asctime)s %(message)s",
#format中的格式可以在basicConfig的说明文档中查看
datefmt="%Y-%m-%d %H:%M:%S",
#时间格式,秒原本为%s但在字符串中%s是占位符,所以这里必须使用%S来解决冲突问题
filename="test.log",#日志文件
filemode="a"#文件操作方式为追加写入
) logging.debug("debug message")
logging.info("info")#最为常用的输出等级
logging.warning("warning")
logging.error("error")
logging.critical("critical") #test.log:
# 2017-04-30 18:41:23 debug message
# 2017-04-30 18:41:23 info
# 2017-04-30 18:41:23 warning
# 2017-04-30 18:41:23 error
# 2017-04-30 18:41:23 critical
其优势就是简单易操作,但缺点很多,比如无法屏幕和文件一起输出等,所以才有了第二种方式
第二种方式,logger:常用的日志配置方式
代码示例:
# 编辑者:闫龙
import logging
logger = logging.getLogger() #实例化一个logger对象
fh = logging.FileHandler("logger2")#实例化一个文件流对象fh
sh = logging.StreamHandler()#实例化一个Stream流对象sh
fm = logging.Formatter("%(asctime)s - %(message)s")
#实例化一个日志格式对象,fm
fh.setFormatter(fm)
#将日志格式对象fm添加到fh对象中,让日志在进行文件输出时的格式是fm中定义的
logger.addHandler(fh)
#将文件流对象fh添加到logger对象中,让日志输出可以是文件流方式
logger.addHandler(sh)
#将文件流对象fh添加到logger对象中,让日志输出可以是Stream流方式
logger.debug("debug message")
logger.info("info")#最为常用的输出等级
logger.warning("warning")
logger.error("error")
logger.critical("critical") #logger2:
# 2017-04-30 18:53:22,324 - warning
# 2017-04-30 18:53:22,324 - error
# 2017-04-30 18:53:22,324 - critical
# 2017-04-30 18:57:53,341 - warning
# 2017-04-30 18:57:53,341 - error
# 2017-04-30 18:57:53,342 - critical
#打印结果:
# warning
# error
# critical
# warning
# error
# critical
按照Yuan先生的理论,Logger配置方式,就像是吸星大法,就是一个吸的过程,你有什么我吸什么,这种方式确实很好理解
Logger方式将来我们要经常用到,所以一定要记住哦
python模块-logging的智商上限的更多相关文章
- python模块 ---logging模块
摘要by crazyhacking: 与log4cxx一样,分为三个部分,logger, handler,formatter. 详细内容参考:1官网http://docs.python.org/2/h ...
- Python模块——logging模块
logging模块简介 logging模块定义的函数和类为应用程序和库的开发实现了一个灵活的事件日志系统.logging模块是Python的一个标准库模块, 由标准库模块提供日志记录API的关键好处是 ...
- python模块--logging
一.logging模块的简单应用 import logging logging.debug('debug message') logging.info('ingo message') logging. ...
- Python模块logging
基本用法: import logging import sys # 获取logger实例,如果参数为空则返回root logger logger = logging.getLogger("A ...
- Python模块-logging模块(一)
logging模块用来写日志文件 有5个级别,debug(),info(),warning(),error()和critical(),级别最高的为critical() debug()为调试模式,inf ...
- [Python 模块] logging模块、Logger类
logging模块: 标准库里面的logging模块,在前面学习线程安全时曾用来解决print被打断的问题,这里会介绍logging模块的功能. logging模块是线程安全的,不需要客户做任何特殊的 ...
- Python模块-logging模块(二)
logging模块记录日志有四个主要类:logger,handler,formatter,filter logger提供了应用程序可以直接使用的接口,每个程序在输出信息之前都要获得一个Logger h ...
- python 模块之-logging
python 模块logging import logging ### 简单使用格式 日志级别等级CRITICAL > ERROR > WARNING > INFO > ...
- python的logging日志模块(二)
晚上比较懒,直接搬砖了. 1.简单的将日志打印到屏幕 import logging logging.debug('This is debug message') logging.info('Thi ...
随机推荐
- Hibernate性能优化之SessionFactory重用
Hibernate优化的方式有很多,如缓存.延迟加载以及与SQL合理映射,通过对SessionFactory使用的优化是最基础的. SessionFactory负责创建Session实例,Sessio ...
- Jmeter—添加断言 判断接口响应数据是否符合预期
发出请求之后,通过添加断言可以判断响应数据是否是我们的预期结果. 1 在Jmeter中发送一个状态返回200的http请求(参数故意输入错误).结果肯定是不是返回200啦. 但结果树中http请求的图 ...
- [UVA 10635] Prince ans Princess
图片加载可能有点慢,请跳过题面先看题解,谢谢 这道题... 还是要点思维的... 第一眼看是个最长公共子序列,但是, \(N\le 62500\) ,并不能 \(O(n^2)\) 求 $ $ 这道题有 ...
- 【BZOJ4872】【Shoi2017】分手是祝愿
Time Limit: 20 Sec Memory Limit: 512 MB Description Zeit und Raum trennen dich und mich. 时空将你我分开 ...
- Java EE之会话
1.需要会话的原因 所有HTTP服务器技术都普遍采用HTTP会话的概念,并且Java EE也在规范中添加了对会话的支持. 维持状态 会话用于维持请求和请求之间的状态.HTTP请求自身是完全无状态的.从 ...
- 不同tab下的列表长度不同,tab的样式和底部的位置不同
要求:当点击不同的tab时,被点击的tab样式不同,产生不同的列表.当列表长度大于屏幕高度时,底部随列表显示:当列表长度小于屏幕高度时,底部固定在屏幕的底部. demo: <!DOCTYPE h ...
- HDU 5306 线段树
吉司机课件题. 区间min,区间最值,区间和. 如果用最大值和次大值能更新区间和那就更新打标记,否则暴力dfs. #include<iostream> #include<cstdio ...
- Chapter1(预科)--C++Prime笔记
心得体会: 因为之前一直在用在学C,因此在看完C++Prime第一章后,就有中在一个培训班中,一个老师用一个简单的项目来带你了解这种语言的特性的感觉.当然这个告诉是在让你脑子固化接受一些点的前提下. ...
- WHY C++ ?(by Herb Sutter) & C++17 standard
WHY C++ ? C++
- python【文件操作:读写文件】
文件读写模式