python实现简单日志记录库glog的使用
作者:悦悦的小屋 发布时间:2023-01-07 23:14:40
这篇文章主要介绍了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?
'''
来源:https://www.cnblogs.com/yuehouse/p/11741993.html
猜你喜欢
- IE(internet explorer)公司:微软(MicroSoft)布局引擎:Trident(也做MSHTML)注:解析渲染
- 本文实例讲述了Python只用40行代码编写的计算器。分享给大家供大家参考,具体如下:效果图:代码:from tkinter import
- 〝 古人学问遗无力,少壮功夫老始成 〞python之tkinter库弹窗messagebox,常码字不易,出精品更难,没有特别幸运,那么请先
- 把中文字符转换回Unicode字符。见下列代码:<%function unicode(str)dim i,j,c,
- LOAD DATA INFILE '文件地址' INTO TABLE 表名 FIELDS TERMINATED BY
- 今天在做sql Server 2005的实验的时候碰到的问题,问题描述很清楚,怀疑是我以前给计算机修改了名称而导致的.可以用select @
- 在获得SA密码后,往往因为服务器管理者或”前人”将net.exe和net1.exe被限制使用,无法添
- 一组常用的弹出窗口用法,以下代码集合常用的弹出窗口用法。1、最基本的弹出窗口代码<SCRIPT LANGUAGE="
- js实现千分符转化function fmoney(s, n){ n = n > 0 && n <= 20 ? n
- Microsoft SQL Server 2000的会话上下文信息使应用程序得以设置二进制值,以便在同一会话或连接上运行的多个批处理、存储过
- 一、引用返回引用返回用在当想用函数找到引用应该被绑定在哪一个变量上面时。不要用返回引用来增加性能,引擎足够聪明来自己进行优化。仅在有合理的技
- 第七步: 在自定义分页的Repeater 里添加排序功能现在已经完成了自定义分页,我们再来添加排序功能。ProductsBLL类的GetPr
- select 终极美化,主要是针对下拉框的美化一个很古老的话题了,不过貌似目前为止也没有比较好的做到,在jxdawei的基础上做了
- 我的长博文不少,比较影响阅读体验,有必要添加一个文章目录功能。相比 Wordpress, Typecho 的插件就比较少了。我想找一个像掘金
- asp ajax json教程首先用ACCESS建json.mdb的库,然后建一个表t_jsontable,字段如下:jt_id,jt_na
- 一、分工和流程在土豆网,以项目开发为核心,谁都可以带项目,担任项目经理。一个典型的土豆网项目中,当进入正式开发阶段,通常参与者包括:1名设计
- 前言np.argmax是用于取得数组中每一行或者每一列的的最大值。常用于机器学习中获取分类结果、计算精确度等。函数:numpy.argmax
- 我是在做行人检测中需要将一段视频变为图片数据集,然后想将视频每秒钟的图片提取出来。语言:python所需要的库:cv2,numpy (自行安
- 如果PyPi上搜html2text的话,找到的是另外一个库:Alir3z4/html2text。这个库是从aaronsw/html2text
- 如何在页面中实现对电子信箱的访问?emaile.htm<HTML><HEAD><META NAME=