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连接mongodb操作数据示例(mongodb数据库配置类)
Dec 31 Python
Python文件去除注释的方法
May 25 Python
Python实现各种排序算法的代码示例总结
Dec 11 Python
详解Django之auth模块(用户认证)
Apr 17 Python
如何用python整理附件
May 13 Python
Python numpy中矩阵的基本用法汇总
Feb 12 Python
Python3多线程基础知识点
Feb 19 Python
Python将视频或者动态图gif逐帧保存为图片的方法
Sep 10 Python
Django将默认的SQLite更换为MySQL的实现
Nov 18 Python
Pytest mark使用实例及原理解析
Feb 22 Python
Python 利用Entrez库筛选下载PubMed文献摘要的示例
Nov 24 Python
Python中的流程控制详解
Feb 18 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
BBS(php & mysql)完整版(八)
2006/10/09 PHP
php join函数应用
2011/05/04 PHP
php源代码安装常见错误与解决办法分享
2013/05/28 PHP
CodeIgniter中使用Smarty3基本配置
2015/06/29 PHP
详解PHP编码转换函数应用技巧
2016/10/22 PHP
中国地区三级联动下拉菜单效果分析
2012/11/15 Javascript
jquery实现带缩略图的可定制高度画廊效果(5种)
2015/08/28 Javascript
从零学习node.js之mysql数据库的操作(五)
2017/02/24 Javascript
详解angular2实现ng2-router 路由和嵌套路由
2017/03/24 Javascript
React Native实现进度条弹框的示例代码
2017/07/17 Javascript
修改 bootstrap table 默认detailRow样式的实例代码
2017/07/21 Javascript
ubuntu编译nodejs所需的软件并安装
2017/09/12 NodeJs
mui上拉加载更多下拉刷新数据的封装过程
2017/11/03 Javascript
Vue 源码分析之 Observer实现过程
2018/03/29 Javascript
Cocos2d实现刮刮卡效果
2018/12/20 Javascript
[05:06]2017亚洲邀请赛DAC回顾片
2017/04/19 DOTA
pycharm远程调试openstack代码
2017/11/21 Python
django中模板的html自动转意方法
2018/05/27 Python
Python使用re模块正则提取字符串中括号内的内容示例
2018/06/01 Python
Selenium鼠标与键盘事件常用操作方法示例
2018/08/13 Python
Python单向链表和双向链表原理与用法实例详解
2018/08/31 Python
浅谈python在提示符下使用open打开文件失败的原因及解决方法
2018/11/30 Python
python 实现selenium断言和验证的方法
2019/02/13 Python
Python for循环通过序列索引迭代过程解析
2020/02/07 Python
python文件编写好后如何实践
2020/07/07 Python
python Matplotlib数据可视化(1):简单入门
2020/09/30 Python
基于Pytorch版yolov5的滑块验证码破解思路详解
2021/02/25 Python
Luxplus丹麦:香水和个人护理折扣
2018/04/23 全球购物
开发中都用到了那些设计模式?用在什么场合?
2014/08/21 面试题
项目资料员岗位职责
2013/12/10 职场文书
2014年护理工作总结范文
2014/11/14 职场文书
班主任工作经验交流会总结
2015/11/02 职场文书
浅谈Python类的单继承相关知识
2021/05/12 Python
python for循环赋值问题
2021/06/03 Python
JAVA API 实用类 String详解
2021/10/05 Java/Android
Unicode中的CJK(中日韩统一表意文字)字符小结
2021/12/06 HTML / CSS