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

标签:python,日志,记录,库,glog
0
投稿

猜你喜欢

  • python实时监控logstash日志代码

    2021-03-08 07:46:49
  • asp生成UTF-8格式的文件方法

    2008-01-26 20:59:00
  • python数据类型之间怎么转换技巧分享

    2023-09-04 02:38:42
  • Python Numpy之linspace用法说明

    2021-10-17 10:49:55
  • Python详细讲解浅拷贝与深拷贝的使用

    2023-01-01 03:00:10
  • python numpy.power()数组元素求n次方案例

    2022-06-26 00:11:22
  • JS变量中有var定义和无var定义的区别以及es6中let命令和const命令

    2024-05-22 10:37:29
  • 基于python操作ES实例详解

    2021-01-06 05:08:28
  • Python内置的字符串处理函数详细整理(覆盖日常所用)

    2023-10-10 22:46:36
  • 浅谈Go中数字转换字符串的正确姿势

    2024-05-08 10:51:42
  • 使用python实现下拉选择框和页签的方法

    2021-10-01 04:07:41
  • 详细分析Python collections工具库

    2022-06-28 01:18:57
  • 微信JSSDK调用微信扫一扫功能的方法

    2024-04-29 13:46:02
  • Windows安装Anaconda并且配置国内镜像的详细教程

    2023-07-06 13:45:15
  • python3.9实现pyinstaller打包python文件成exe

    2022-10-28 18:27:35
  • MySQL数据库单一表突破4G限制的实现方法

    2008-11-02 14:43:00
  • Python 如何将integer转化为罗马数(3999以内)

    2023-01-19 12:46:51
  • pygame库实现俄罗斯方块小游戏

    2022-09-11 10:43:37
  • 完美解决Python matplotlib绘图时汉字显示不正常的问题

    2023-09-28 05:30:55
  • MySQL单表查询常见操作实例总结

    2024-01-20 05:47:17
  • asp之家 网络编程 m.aspxhome.com