python实现简单日志记录库glog的使用


Posted in Python onDecember 13, 2019

这篇文章主要介绍了python实现简单日志记录库glog的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

一、 glog的简介
glog所记录的日志信息总是记录到标准的stderr中,即控制台终端。

每一行日志记录总是会添加一个谷歌风格的前缀,即google-style log prefix, 它的形式如下:

E0924 22:19:15.123456 19552 filename.py:87] some message

上面红色部分加粗的就是谷歌风格的日志前缀,每一个部分都有其含义,定义如下:

(1)第一个字母表示日志的类型,E表示error,I表示info,W表示warning,F表示fatal

(2)紧接在后面的表示记录日志的时间,格式为MMDD,比如这里0924,表示的是9月24日

(3)紧接在日期后面的是时间,格式为HH:MM:SS.microseconds,比如这里的时间是22时19分15秒123456毫秒

(4)紧接着是进程的ID,即Process ID,也就是上面的19552

(5)紧接着是运行的程序文件,比如test.py

(6)最后是记录这一句日志是在文件中的哪一行发生的,比如87,指的是这句话是在py文件中的87行

二、glog有哪些功能
我们大致看一下glog模块里面定义的方法

复制代码
"""A simple Google-style logging wrapper."""

import logging
import time
import traceback
import os

import gflags as flags

# 这些方法其实都是来自于logging模块
debug = logging.debug
info = logging.info
warning = logging.warning
warn = logging.warning
error = logging.error
exception = logging.exception
fatal = logging.fatal
log = logging.log

DEBUG = logging.DEBUG
INFO = logging.INFO
WARNING = logging.WARNING
WARN = logging.WARN
ERROR = logging.ERROR
FATAL = logging.FATAL

#下面这些方法常用来检查某些条件或者是结果,然后根据实际情况输出日志信息
def check_failed(message):

def check(condition, message=None):

def check_eq(obj1, obj2, message=None):

def check_ne(obj1, obj2, message=None):

def check_le(obj1, obj2, message=None):

def check_ge(obj1, obj2, message=None):

def check_lt(obj1, obj2, message=None):

def check_gt(obj1, obj2, message=None):
复制代码
logging提供了一组便利的函数,用来做简单的日志。它们是 debug()、 info()、 warning()、 error() 和 critical()。

logging以严重程度递增排序:

DEBUG:详细信息,一般只在调试问题时使用

INFO:证明事情按预期工作

WARNING:某些没有预料到的时间提示,或者在将来可能会出现的问题提示。例如:磁盘空间不足,但是软件还是会照常运作

ERROR:由于更严重的问题,软件已不能执行一些功能了

CRITICAL:严重错误,表明软件已不能继续运行了

级别排序:CRITICAL>ERROR>WARNING>INFO>DEBUG

默认等级是WARNING

三、glog模块的简单示例

import glog
 
a=100
if a==100:
  glog.info("a=100")
 
b=0
if b==0:
  glog.error("b=0!")
  glog.fatal("b is 0")
  glog.warn("b is really 0?")
'''运行结果为:
I0626 15:35:54.071558 17300 test.py:10] a=100
E0626 15:35:54.072561 17300 test.py:14] b=0!
F0626 15:35:54.072561 17300 test.py:15] b is 0
W0626 15:35:54.072561 17300 test.py:16] b is really 0?
'''

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

Python 相关文章推荐
十条建议帮你提高Python编程效率
Feb 16 Python
python3调用R的示例代码
Feb 23 Python
python range()函数取反序遍历sequence的方法
Jun 25 Python
pygame实现简易飞机大战
Sep 11 Python
Python+threading模块对单个接口进行并发测试
Jun 25 Python
python实现微信自动回复机器人功能
Jul 11 Python
python实现电子书翻页小程序
Jul 23 Python
python3 实现爬取TOP500的音乐信息并存储到mongoDB数据库中
Aug 24 Python
window7下的python2.7版本和python3.5版本的opencv-python安装过程
Oct 24 Python
Python 利用邮件系统完成远程控制电脑的实现(关机、重启等)
Nov 19 Python
Python函数调用追踪实现代码
Nov 27 Python
用Python 执行cmd命令
Dec 18 Python
利用matplotlib实现根据实时数据动态更新图形
Dec 13 #Python
Python3将jpg转为pdf文件的方法示例
Dec 13 #Python
如何使用python3获取当前路径及os.path.dirname的使用
Dec 13 #Python
PyQt5多线程刷新界面防假死示例
Dec 13 #Python
wxpython多线程防假死与线程间传递消息实例详解
Dec 13 #Python
python-web根据元素属性进行定位的方法
Dec 13 #Python
python Jupyter运行时间实例过程解析
Dec 13 #Python
You might like
php生成EXCEL的东东
2006/10/09 PHP
PHP 文件上传源码分析(RFC1867)
2009/10/30 PHP
PHP抓取淘宝商品的用户晒单评论+图片+搜索商品列表实例
2016/04/14 PHP
CentOS 上搭建 PHP7 开发测试环境
2017/02/26 PHP
创建无限极分类树型结构的简单方法
2017/06/20 PHP
用javascript动态调整iframe高度的代码
2007/04/10 Javascript
网页和浏览器兼容性问题汇总(draft1)
2009/06/01 Javascript
js 关于=+与+=日期函数使用说明(赋值运算符)
2011/11/15 Javascript
深入分析jquery解析json数据
2014/12/09 Javascript
jquery中trigger()无法触发hover事件的解决方法
2015/05/07 Javascript
javascript中的altKey 和 Event属性大全
2015/11/06 Javascript
Javascript技术难点之apply,call与this之间的衔接
2015/12/04 Javascript
JS正则表达式验证中文字符
2017/05/08 Javascript
详解plotly.js 绘图库入门使用教程
2018/02/23 Javascript
JS实现的base64加密解密操作示例
2018/04/18 Javascript
原生JS实现的碰撞检测功能示例
2018/05/18 Javascript
vue组件name的作用小结
2018/05/23 Javascript
微信小程序自定义组件之可清除的input组件
2018/07/17 Javascript
Vue导出页面为PDF格式的实现思路
2018/07/31 Javascript
Vue中的Props(不可变状态)
2018/09/29 Javascript
浅谈element中InfiniteScroll按需引入的一点注意事项
2020/06/05 Javascript
用Python生成器实现微线程编程的教程
2015/04/13 Python
python获取本机外网ip的方法
2015/04/15 Python
python类和继承用法实例
2015/07/07 Python
Python数据结构与算法之图结构(Graph)实例分析
2017/09/05 Python
selenium判断元素是否存在的两种方法小结
2020/12/07 Python
CSS3中动画属性transform、transition和animation属性的区别
2016/09/25 HTML / CSS
大学军训通讯稿
2014/01/13 职场文书
党员公开承诺事项
2014/03/25 职场文书
成绩单公证书
2014/04/10 职场文书
2014年创卫工作总结
2014/11/24 职场文书
员工家属慰问信
2015/03/24 职场文书
刑事申诉状范文
2015/05/20 职场文书
Python 正则模块详情
2021/11/02 Python
python 安全地删除列表元素的方法
2022/03/16 Python
动画「半妖的夜叉姬」新BD特典图公开
2022/03/22 日漫