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的智商上限的更多相关文章

  1. python模块 ---logging模块

    摘要by crazyhacking: 与log4cxx一样,分为三个部分,logger, handler,formatter. 详细内容参考:1官网http://docs.python.org/2/h ...

  2. Python模块——logging模块

    logging模块简介 logging模块定义的函数和类为应用程序和库的开发实现了一个灵活的事件日志系统.logging模块是Python的一个标准库模块, 由标准库模块提供日志记录API的关键好处是 ...

  3. python模块--logging

    一.logging模块的简单应用 import logging logging.debug('debug message') logging.info('ingo message') logging. ...

  4. Python模块logging

    基本用法: import logging import sys # 获取logger实例,如果参数为空则返回root logger logger = logging.getLogger("A ...

  5. Python模块-logging模块(一)

    logging模块用来写日志文件 有5个级别,debug(),info(),warning(),error()和critical(),级别最高的为critical() debug()为调试模式,inf ...

  6. [Python 模块] logging模块、Logger类

    logging模块: 标准库里面的logging模块,在前面学习线程安全时曾用来解决print被打断的问题,这里会介绍logging模块的功能. logging模块是线程安全的,不需要客户做任何特殊的 ...

  7. Python模块-logging模块(二)

    logging模块记录日志有四个主要类:logger,handler,formatter,filter logger提供了应用程序可以直接使用的接口,每个程序在输出信息之前都要获得一个Logger h ...

  8. python 模块之-logging

    python  模块logging import logging ###  简单使用格式    日志级别等级CRITICAL > ERROR > WARNING > INFO > ...

  9. python的logging日志模块(二)

    晚上比较懒,直接搬砖了. 1.简单的将日志打印到屏幕   import logging logging.debug('This is debug message') logging.info('Thi ...

随机推荐

  1. IPV6的链路本地地址和站点本地地址的不同

    转帖 中关村 http://ask.zol.com.cn/x/2230274.html IPV6涉及到一个概念,link-local address, 中文叫“链路本地地址”,它的前缀是FE80::/ ...

  2. java类和对象

    类是对象的抽象 对象是类的一个实例类 对象 = new 类();拿对象可以操作这个类里的方法 java类与对象的区别是个老生常谈的问题,刚开始学java的时候就开始接触类和对象,今天来总结一下他们之间 ...

  3. MySQL中varchar最大长度是多少

    一. varchar存储规则: 4.0版本以下,varchar(20),指的是20字节,如果存放UTF8汉字时,只能存6个(每个汉字3字节) 5.0版本以上,varchar(20),指的是20字符,无 ...

  4. Hadoop2.6 安装布置问题总结(单机、分布式)

    在debian7虚拟机上安装hadoop2.6,期间遇到一些问题在此记录一下. 安装参考: Hadoop安装教程_单机/伪分布式配置_Hadoop2.6.0/Ubuntu14.04 Hadoop集群安 ...

  5. shell的sort命令

    sort命令以行为单位对文本进行排序. 命令语法: sort [-b/d/f/g/i/M/n/r] [InFile] 参数解释: -b: ignore-leading-blanks,忽略前面空格符部分 ...

  6. 20135239 益西拉姆 linux内核分析 扒开系统调用的三层皮(下)

    一. 给MenuOS增加time-asm命令 代码解释 1.-rf:强制删除 2.clone :重新克隆 3.time-asm:显示系统时间的汇编形式 给MenuOS增加time和time-asm命令 ...

  7. oracle 11g 压缩数据文件

    通过以下语句直接分析出每个数据库文件可压缩量 select a.file#, a.name, a.bytes CurrentMB, ceil(HWM ResizeTo, (a.bytes Releas ...

  8. 【bzoj2795】【Poi2012】A Horrible Poem

    题解: 询问区间的整循环节 设区间长度为$n$ 如果有循环节长为$x$和$y$,那由斐蜀定理得$gcd(x,y)$也一定为一个循环节: 假设最小的循环节长为$mn$,那么对于任何循环节长$x$,一定$ ...

  9. python之旅:并发编程之多线程

    一 threading模块介绍 multiprocess模块的完全模仿了threading模块的接口,二者在使用层面,有很大的相似性,因而不再详细介绍 官网链接:https://docs.python ...

  10. linux kill 掉所有匹配到名字的进程

    如,要 kill 掉 swoole 相关的进程 ps aux | grep swoole |  awk '{print $2}' | xargs kill -9 ps 列出所有进程, 参数: a -  ...