python  logging日志打印过程解析


Posted in Python onOctober 22, 2019

一、 基础使用

1.1 logging使用场景

日志是什么?这个不用多解释。百分之九十的程序都需要提供日志功能。Python内置的logging模块,为我们提供了现成的高效好用的日志解决方案。但是,不是所有的场景都需要使用logging模块,下面是Python官方推荐的使用方法:

任务场景 最佳工具
普通情况下,在控制台显示输出 print()
报告正常程序操作过程中发生的事件 logging.info()(或者更详细的logging.debug())
发出有关特定事件的警告 warnings.warn()或者logging.warning()
报告错误 弹出异常
在不引发异常的情况下报告错误 logging.error(), logging.exception()或者logging.critical()

logging模块定义了下表所示的日志级别,按事件严重程度由低到高排列(注意是全部大写!因为它们是常量。):

级别 级别数值 使用时机
DEBUG 10 详细信息,常用于调试。
INFO 20 程序正常运行过程中产生的一些信息。
WARNING 30 警告用户,虽然程序还在正常工作,但有可能发生错误。
ERROR 40 由于更严重的问题,程序已不能执行一些功能了。
CRITICAL 50 严重错误,程序已不能继续运行。

默认级别是WARNING,表示只有WARING和比WARNING更严重的事件才会被记录到日志内,低级别的信息会被忽略。因此,默认情况下,DEBUG和INFO会被忽略,WARING、ERROR和CRITICAL会被记录。

有多种方法用来处理被跟踪的事件。最简单的方法就是把它们打印到终端控制台上。或者将它们写入一个磁盘文件内。

1.2 简单范例

在什么都不配置和设定的情况下,logging会简单地将日志打印在显示器上,如下例所示:

import logging
logging.warning('Watch out!') # 消息会被打印到控制台上
logging.info('I told you so') # 这行不会被打印,因为级别低于默认级别

如果,将上面的代码放在一个脚本里并运行,结果是:

WARNING:root:Watch out!

1.3 高级使用

import logging

#创建logger记录器
logging.basicConfig(filename='example.log',level=logging.DEBUG)
logger = logging.getLogger('simple_example')
logger.setLevel(logging.DEBUG)

#创建一个控制台处理器,并将日志级别设置为debug

ch = logging.StreamHandler()

ch.setLevel(logging.DEBUG)

#创建formatter格式化器
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')

#将formatter 添加到ch处理器
ch.setFormatter(formatter)

#将ch添加到logger
logger.addHandler(ch)

#然后就可以开始使用了
# logger.debug('debug message')
#logger.info('info message')
# logger.warning('warn message')
# logger.error('error message')
# logger.critical('critical message')

def Logss():
  #要打印的信息
  a = "3"
  logger.info(a)

Logss()

python  logging日志打印过程解析

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python网络爬虫实例讲解
Apr 28 Python
详解python发送各类邮件的主要方法
Dec 22 Python
python3利用Dlib19.7实现人脸68个特征点标定
Feb 26 Python
python编辑用户登入界面的实现代码
Jul 16 Python
python实现指定字符串补全空格、前面填充0的方法
Nov 16 Python
Python实现的旋转数组功能算法示例
Feb 23 Python
python SQLAlchemy的Mapping与Declarative详解
Jul 04 Python
Django实现web端tailf日志文件功能及实例详解
Jul 28 Python
django连接oracle时setting 配置方法
Aug 29 Python
python实现猜数字游戏
Mar 25 Python
python爬虫快速响应服务器的做法
Nov 24 Python
python实现层次聚类的方法
Nov 01 Python
安装2019Pycharm最新版本的教程详解
Oct 22 #Python
Python列表list常用内建函数实例小结
Oct 22 #Python
Python爬虫使用浏览器cookies:browsercookie过程解析
Oct 22 #Python
Python异常模块traceback用法实例分析
Oct 22 #Python
Python多线程爬取豆瓣影评API接口
Oct 22 #Python
Python Process多进程实现过程
Oct 22 #Python
详解python中eval函数的作用
Oct 22 #Python
You might like
如何在PHP中使用Oracle数据库(4)
2006/10/09 PHP
php+ajax 实现输入读取数据库显示匹配信息
2015/10/08 PHP
PHP7 新增常量
2021/03/09 PHP
js Select下拉列表框进行多选、移除、交换内容的具体实现方法
2013/08/13 Javascript
点击表单提交时出现jQuery没有权限的解决方法
2014/07/23 Javascript
判断日期是否能跨月查询的js代码
2014/07/25 Javascript
jquery实现在光标位置插入内容的方法
2015/02/05 Javascript
js时钟翻牌效果实现代码分享
2020/07/31 Javascript
基于jQuery实现自动轮播旋转木马特效
2015/11/02 Javascript
三个js循环的关键字示例(for与while)
2016/02/16 Javascript
JS获取字符串实际长度(包含汉字)的简单方法
2016/08/11 Javascript
Vue.js双向绑定操作技巧(初级入门)
2016/12/27 Javascript
JavaScript基于DOM操作实现简单的数学运算功能示例
2017/01/16 Javascript
react学习笔记之state以及setState的使用
2017/12/07 Javascript
深入理解ES6中let和闭包
2018/02/22 Javascript
小程序自定义组件实现城市选择功能
2018/07/18 Javascript
vue 下列表侧滑操作实例代码详解
2018/07/24 Javascript
基于JavaScript实现瀑布流布局
2018/08/15 Javascript
在微信小程序中使用图表的方法示例
2019/04/25 Javascript
从零搭一个自用的前端脚手架的方法步骤
2019/09/23 Javascript
浅谈Python的文件类型
2016/05/30 Python
Python解决八皇后问题示例
2018/04/22 Python
python实现验证码识别功能
2018/06/07 Python
Python实现将Excel转换成为image的方法
2018/10/23 Python
python实现两个dict合并与计算操作示例
2019/07/01 Python
python中什么是面向对象
2020/06/11 Python
关于tf.matmul() 和tf.multiply() 的区别说明
2020/06/18 Python
Ubuntu权限不足无法创建文件夹解决方案
2020/11/14 Python
html5 canvas实现跟随鼠标旋转的箭头
2016/03/11 HTML / CSS
HTML5计时器小例子
2013/10/15 HTML / CSS
服务员岗位职责
2014/01/29 职场文书
教师自我反思材料
2014/02/14 职场文书
八项规定整改方案
2014/10/01 职场文书
2014年护士长工作总结
2014/11/11 职场文书
煤矿安全保证书
2015/02/27 职场文书
Nginx 路由转发和反向代理location配置实现
2021/11/11 Servers