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 ...
随机推荐
- Windows 常用快捷方式
gpedit.msc-----组策略sndrec32-----录音机nslookup----- ip地址侦测器explorer------ 打开资源管理器logoff-------注销命令tsshut ...
- [转帖]脑残式网络编程入门(一):跟着动画来学TCP三次握手和四次挥手
脑残式网络编程入门(一):跟着动画来学TCP三次握手和四次挥手 http://www.52im.net/thread-1729-1-1.html 1.引言 网络编程中TCP协议的三次握手和 ...
- 安装iproute2
yum install -y gcc bison flex #tar -xzf iproute2-3.17.0.tar.gz #cd iproute2-3.17.0#sed -i '/^TARGET ...
- centos6.7 安装JDK
1.卸载JDK 查看系统是否已安装JDK.一般的linux都默认使用了开源的openJDK.显示JDK版本信息,已经安装JDK,否则没有安装.命令行: [root@localhost ~]# ja ...
- Linux/Unix系统编程手册 第三章:系统编程概念
本章介绍系统编程的基础概念和一些后续章节用到的函数及头文件,并说明了可移植性问题. 系统调用是受控的内核入口,通过系统调用,进程可以请求内核以自己的名义去执行某些动作,比如创建子进程,执行I/O操作, ...
- selenium实战之斗鱼弹幕
python3.6.selenium.chromedriver 先上代码 from selenium import webdriver from time import sleep driver=we ...
- 关于UIInterfaceOrientation的一个bug
在ios中获取设备当前方向的枚举有UIInterfaceOrientation和UIDeviceOrientation ,前者包含枚举 Unknown//未知 Portrait//屏幕竖直,home键 ...
- 【Learning】辛普森积分
辛普森积分 这种积分法很暴力:只要求你实现出函数求值\(f(x)\). 使用辛普森积分,我们可以求出函数一段区间\([l,r]\)的近似积分.记\(mid=\frac{l+r}2\),有: \[ \i ...
- bzoj 4358: permu 莫队
第一步先莫队分块. 对于每一块l~r,初始右端点设为r+1,然后每个询问先将右端点往右移,然后处理询问在l~r之间的部分,最后用一个栈再把l~r的复原. 具体来说是维护两个数组now1和now2,一个 ...
- 团体程序设计天梯赛 L1-010. 比较大小
测试数据: 1 2 3 1 3 2 2 1 3 2 3 1 3 1 2 3 2 1 Code: 先确定最小,然后确定第二小 #include <stdio.h> #include < ...