python常用模块——logger模块
python的logging模块提供了通用的日志系统,熟练使用logging模块可以方便开发者开发第三方模块或者是自己的python应用。
python使用logging模块记录日志涉及四个主要的类:
logger:提供了应用程序可以直接使用的接口;
handler:将(logger创建的)日志记录发送到合适的目的地。
filter:提供一种优雅地方式决定一个日志记录是否发送到handler。
formatter:指定日志记录输出的具体格式。formatter的构造方法需要两个参数:消息的格式字符串和日期字符串,这两个参数都是可选的。
logging.getLogger([name]):返回一个logger对象,如果没有指定名字将返回root logger。
logging.basicConfig():用默认Formatter为日志系统建立一个StreamHandler,设置基础配置并加到root logger中
日志打印有5中模式:
logging.debug():调试模式,不是必须出现,但是如果有问题需要借助它的信息。
logging.info():信息模式,必须出现但是对程序的正常运行没有影响。
logging.warning():警告模式,不会造成程序的错误,但可能会出问题的时候打印。
logging.erroe():错误模式,程序出错了。
loggingcirtical():批判模式,程序崩溃了。
每个程序在输出信息之前都要获得一个Logger,Logger通常对应了程序的模块名。
LOG = logging.getLogger("chat.gui")
而核心模块可以这样:
LOG = logging.getLogger("chat.kernel")
Logger.setLevel(lel):指定最低的日志级别,低于lel的级别将会被忽略。debug是最低的内置级别,critical为最高。
Logger.addFilter(filt)、Logger.removeFilter(filt):添加或删除指定的filter.
Logger.addHandler(hdr)、Logger.removeHandler(hdr):增加或删除指定的handler
不同模式的运行级别:
>>> import logging
>>> logging.NOTSET
0
>>> logging.DEBUG
10
>>> logging.INFO
20
>>> logging.WARNING
30
>>> logging.ERROR
40
>>> logging.CRITICAL
50
NOTSET < DEBUG < INFO < WARNING < ERROR < CRITICAL
如果把looger的级别设置为INFO,那么小于INFO级别的日志不输出,大于等于INFO级别的日志都输出。
handler对象负责发送相关的信息到指定目的地。python的日志系统有多种Handler可以使用。有些Handler可以把信息输出到控制台,有些logger可以把信息输出到文件,还有些Handler可以把信息发送到网上,如果觉得不够用,还可以编写自己的Handler可以通过addHandler()方式添加多个handler
Handler.setLevel(lel):指定被处理的信息级别,低于lel级别的信息将被忽略。
Handler.setFormatter():给这个handler选择一个格式
Handler.addFilter(filt)、Handler.removeFilter:新增或删除一个filter对象。
每个Logger可以附加多个Handler,下面是几个常见的:
(1)logging.StreamHander:屏幕流对象
(2)logging.Filehandler:用于向一个文件输出日志信息
Formatters
Formatter对于设置日志信息最后的规则、结构和内容,默认的时间格式为%Y-%m-%d %H:%M:%S
import logging
LOG=logging.getLogger() #获取一个实例
sh = logging.StreamHandler() #得到一个屏幕流发送台 LOG.addHandler(sh) #作用台关联到实例 LOG.warning('logger warning message')#调用实例答应信息
LOG.error('logger error message') #没有格式化,只有最原始的输出到屏幕
结果:
logger warning message #输出到屏幕
logger error message
下面只单纯输出到文件:
import logging
LOG=logging.getLogger() #获取一个实例 console = logging.FileHandler('test.log') #控制台
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
LOG.addHandler(console) console.setFormatter(formatter) #绑定格式
LOG.warning('logger warning message')
LOG.error('logger error message')
结果:
2017-11-23 20:46:49,396 - root - WARNING - logger warning message
2017-11-23 20:46:49,396 - root - ERROR - logger error message
综合实例:
import logging logger = logging.getLogger() #实例化一个logger对象
# 创建一个handler,用于写入日志文件
fh = logging.FileHandler('test.log') #将相关信息发送到目的地 # 再创建一个handler,用于输出到控制台
ch = logging.StreamHandler()
#指定文件,可以不指定
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') fh.setFormatter(formatter) #文件句柄 绑 格式,
ch.setFormatter(formatter) logger.setLevel(logging.INFO) 设置文件的级别,默认VWARNING logger.addHandler(fh) #logger对象可以添加多个fh和ch对象(logger绑文件句柄)
logger.addHandler(ch) logger.debug('logger debug message') #输出
logger.info('logger info message')
logger.warning('logger warning message')
logger.error('logger error message')
logger.critical('logger critical message')
python常用模块——logger模块的更多相关文章
- Python常用内建模块
Python常用内建模块 datetime 处理日期和时间的标准库. 注意到datetime是模块,datetime模块还包含一个datetime类,通过from datetime import da ...
- python中的logger模块
logger 提供了应用程序可以直接使用的接口handler将(logger创建的)日志记录发送到合适的目的输出filter提供了细度设备来决定输出哪条日志记录formatter决定日志记录的最终输出 ...
- python常用内建模块 collections,bs64,struct,hashlib,itertools,contextlib,xml
# 2 collections 是Python内建的一个集合模块,提供了许多有用的集合类. # 2.1 namedtuple #tuple可以表示不变集合,例如,一个点的二维坐标就可以表示成: p ...
- Python 常用内建模块(time ,datetime)
1,在Python中,与时间处理有关的模块就包括:time,datetime以及calendar. 2,在Python中,通常有这几种方式来表示时间:1)时间戳 2)格式化的时间字符串 3)元组(st ...
- python基础知识~logger模块
一 配置文件模块 import logging ->导入模块 logger = logging.getLogger('mylogger') ->初始化类二 创建句柄 1 文件句柄 fh = ...
- python常用命令—查看模块所在位置
环境:ipython3 交互式解释器 语法: import 模块名 模块名.__file__ 功能: 查看模块的所在位置 例:
- python常用函数及模块
原文来源于博客园和CSDN 1.计算函数 abs()--取绝对值 max()--取序列最大值,包括列表.元组 min()--取序列最小值 len()--取长度 divmod(a,b)---取a//b除 ...
- python中的logger模块详细讲解
logger 提供了应用程序可以直接使用的接口handler将(logger创建的)日志记录发送到合适的目的输出filter提供了细度设备来决定输出哪条日志记录formatter决定日志记录的最终输出 ...
- Python 常用内建模块(os, sys,random)
一.os 模块 1,操作系统与环境变量 import osprint(os.name) #操作系统类型,如果是posix 说明系统是linux unix 或 mac os x :如果是nt 就是win ...
随机推荐
- 551. Student Attendance Record I【easy】
551. Student Attendance Record I[easy] You are given a string representing an attendance record for ...
- nyoj 1129 Salvation
题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=1129 题目分析:感觉题目说的不是多么的清晰,看了别人的分析觉得,也就是说在一个方向不能拐 ...
- codeforces #363a Launch of Collider
A. Launch of Collider time limit per test 2 seconds memory limit per test 256 megabytes input standa ...
- jdbctemplate中的query(sql,params,mapper)与queryForList(sql,params,class)区别
query(sql,params,mapper):是针对自定义对象类型的查询语句,比如: jdbcTrade.query(sql, params, new AMapper()); queryForLi ...
- wp8 各种启动器
PhoneCallTask 打电话 需要 ID_CAP_PHONEDIALER Windows Phone 8, Windows Phone OS 7.1
- iOS 全屏播放网页视频退出后状态栏被隐藏
使用wkWebView播放网页上的视频,播放完成后,退出视频返回到网页发现app的状态整个被隐藏了,解决方法,监听状态栏隐藏通知,在适当的时候让状态栏显示出来 [[NSNotificationCent ...
- 内核交互--procfs
文档介绍:http://lxr.linux.no/linux+v2.6.37/Documentation/filesystems/proc.txt以下内容抄录linux设备驱动开发详解-宋宝华在/pr ...
- TP5 Session Db驱动
一.下载附件,解压,文件路径\extend\driver\session\Db.php 驱动文件下载:Db.php 二.创建数据表 DROP TABLE IF EXISTS `platform_ses ...
- Consul实现原理系列文章1: 用Raft来实现分布式一致性
工作中用到了Consul来做服务发现,之后一段时间里,我会陆续发一些文章来讲述Consul实现原理.在前一篇文章中,我介绍了Raft算法.这篇文章会讲讲Consul是如何使用Raft算法来实现分布式一 ...
- Discuz二次开发手册
Discuz文件说明,有助于discuz爱好者,进行自己的开发,在这里提供方便 admincp.php——后台系统设置主程序文件,一般只处理菜单的显示的访问权限,不处理管理控制. ajax.php—— ...