日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python logging模块的作用及应用场景_Python logging模块原理解析及应用

發(fā)布時間:2024/7/19 python 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python logging模块的作用及应用场景_Python logging模块原理解析及应用 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

一、logging日志模塊等級

常見log級別從高到低:

CRITICAL 》ERROR 》WARNING 》INFO 》DEBUG,默認等級為WARNING,即>=WARNING級別的log才輸出。

日志等級(level)

描述

CRITICAL

當發(fā)生嚴重錯誤,導(dǎo)致應(yīng)用程序不能繼續(xù)運行時記錄的信息

ERROR

由于一個更嚴重的問題導(dǎo)致某些功能不能正常運行時記錄的信息

WARNING

當某些不期望的事情發(fā)生時記錄的信息(如,磁盤可用空間較低),但是此時應(yīng)用程序還是正常運行的

INFO

信息詳細程度僅次于DEBUG,通常只記錄關(guān)鍵節(jié)點信息,用于確認一切都是按照我們預(yù)期的那樣進行工作

DEBUG

最詳細的日志信息,典型應(yīng)用場景是 問題診斷

二、logging模塊的使用方式介紹

logging模塊提供了兩種記錄日志的方式:

第一種方式是使用logging提供的模塊級別的函數(shù)

第二種方式是使用Logging日志系統(tǒng)的四大組件

其實,logging所提供的模塊級別的日志記錄函數(shù)也是對logging日志系統(tǒng)相關(guān)類的封裝而已。

(1)logging模塊定義的模塊級別的常用函數(shù)

函數(shù)

說明

logging.debug(msg, *args, **kwargs)

創(chuàng)建一條嚴重級別為DEBUG的日志記錄

logging.info(msg, *args, **kwargs)

創(chuàng)建一條嚴重級別為INFO的日志記錄

logging.warning(msg, *args, **kwargs)

創(chuàng)建一條嚴重級別為WARNING的日志記錄

logging.error(msg, *args, **kwargs)

創(chuàng)建一條嚴重級別為ERROR的日志記錄

logging.critical(msg, *args, **kwargs)

創(chuàng)建一條嚴重級別為CRITICAL的日志記錄

logging.log(level, *args, **kwargs)

創(chuàng)建一條嚴重級別為level的日志記錄

logging.basicConfig(**kwargs)

對root logger進行一次性配置

其中l(wèi)ogging.basicConfig(**kwargs)函數(shù)用于指定“要記錄的日志級別”、“日志格式”、“日志輸出位置”、“日志文件的打開模式”等信息,其他幾個都是用于記錄各個級別日志的函數(shù)。

(2)logging模塊的四大組件

組件

說明

loggers

提供應(yīng)用程序代碼直接使用的接口

handlers

用于將日志記錄發(fā)送到指定的目的位置

filters

提供更細粒度的日志過濾功能,用于決定哪些日志記錄將會被輸出(其它的日志記錄將會被忽略)

formatters

用于控制日志信息的最終輸出格式

三、自定義Logger模塊類

# testLog1.py

import logging

import time

class Logger():

def __init__(self, logger, level=logging.DEBUG):

'''     : 自定義Logger模塊類

: logger: logger名

: level: 日志級別

'''

# 創(chuàng)建一個logger

self.logger = logging.getLogger(logger)

self.logger.setLevel(level)

# 定義handler的輸出格式

curr_time = time.strftime("%Y-%m-%d")

self.LogFileName = 'log' + curr_time + '.txt'

fmt = logging.Formatter('%(asctime)s - %(filename)s:[%(lineno)s] - [%(levelname)s] - %(message)s')

# asctime: 日志事件發(fā)生的時間

# filename: 源文件的名稱部分,包含文件后綴

# lineno: 調(diào)用日志記錄函數(shù)的源代碼所在的行號

# evelname: 該日志記錄的文字形式的日志級別

# message: 日志記錄的文本內(nèi)容

# 創(chuàng)建一個handler, 用于寫入日志文件

fh = logging.FileHandler(self.LogFileName)

fh.setLevel(logging.DEBUG)

fh.setFormatter(fmt)

# 再創(chuàng)建一個handler,用于輸出到控制臺

ch = logging.StreamHandler()

ch.setLevel(logging.DEBUG)

ch.setFormatter(fmt)

# 給logger添加handler

self.logger.addHandler(fh)

self.logger.addHandler(ch)

# level優(yōu)先級

# logger.setLevel > handler.setLevel > logging.basicConfig

if __name__ == "__main__":

log = Logger(__name__, level=logging.DEBUG)

log.logger.debug('debug')

log.logger.log(logging.DEBUG, 'debug')# 執(zhí)行testLog1.py,則控制臺輸出如下:2020-08-03 20:36:47,104 - testLog1.py:[117] - [DEBUG] - debug2020-08-03 20:36:47,104 - testLog1.py:[118] - [DEBUG] - debug# 日志文件記錄如下:2020-08-03 20:36:15,982 - testLog1.py:[117] - [DEBUG] - debug2020-08-03 20:36:15,982 - testLog1.py:[118] - [DEBUG] - debug

# testLog2.py

from testLog1 import Logger

import traceback

log = Logger(__name__)

def func():

try:

assert 1==2

except Exception:

log.logger.info('測試失敗,輸出信息如下:{}'.format(traceback.format_exc()))    # traceback.format_exc() 會返回異常信息的字符串

if __name__ == "__main__":

func()# 執(zhí)行testLog2.py,則控制臺輸出如下:2020-08-03 20:43:44,907 - testLog2.py:[11] - [INFO] - 測試失敗,輸出信息如下:Traceback (most recent call last):? File "E:/imooc/testLog.py", line 9, in func??? assert 1==2AssertionError# 日志文件記錄如下:2020-08-03 20:43:44,907 - testLog2.py:[11] - [INFO] - 測試失敗,輸出信息如下:Traceback (most recent call last):? File "E:/imooc/testLog.py", line 9, in func??? assert 1==2AssertionError

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習有所幫助,也希望大家多多支持python博客。

總結(jié)

以上是生活随笔為你收集整理的python logging模块的作用及应用场景_Python logging模块原理解析及应用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产第6页 | 国产精品日韩欧美一区二区三区 | 丰满人妻中伦妇伦精品app | 私人av | 少妇视频在线观看 | 麻豆影视在线观看 | 大学生av| 久久精品视频9 | 久久久国产一区二区 | 91精品人妻一区二区三区果冻 | 国产精品久久久久久人 | 亚洲av综合色区 | 亚洲AV无码久久精品国产一区 | 久久成人免费 | 成人免费精品视频 | 99精品视频免费 | a毛片在线 | 日韩精品高清在线 | 久久久人体 | 精品啪啪| 欧美日韩大片在线观看 | 欧美日韩精品区 | 免费视频国产 | 粉嫩小箩莉奶水四溅在线观看 | 亚洲高潮 | 91女神在线 | 五个女闺蜜把我玩到尿失禁 | 国产又粗又猛视频免费 | 森泽佳奈av | 久久久久久久久久久久久久久久久久久 | 亚洲精品乱码久久久久久日本蜜臀 | 国产成人精品免费网站 | 九九热精品视频在线播放 | 人人爽人人爽人人片 | 国产suv精品一区二区6 | 国产伦精品一区二区三区在线 | 国产福利视频在线观看 | 97色资源 | 丁香六月av | av中文在线资源 | 精品人妻无码一区二区色欲产成人 | 亚洲一级二级片 | a一级视频 | 欧美激情伊人 | 五级 黄 色 片 | 国产天堂视频 | 欧美aa在线观看 | 女女同性女同一区二区三区按摩 | 4hu在线观看 | 国产偷人妻精品一区二区在线 | 91精彩刺激对白 | ass精品国模裸体欣赏pics | 黄色三级网站 | 精品999久久久一级毛片 | 日本中文字幕在线观看视频 | 国产精品欧美大片 | 成人欧美一区二区三区在线播放 | 男人添女人下部高潮全视频 | 亚洲系列| 三上悠亚激情av一区二区三区 | 麻豆自拍偷拍 | 国产区网址| 麻豆视频免费入口 | 亚洲精品美女 | 亚洲欧美一区二区三区情侣bbw | 毛片传媒| 探花国产精品一区二区 | 国产天天综合 | 国产精品久久久久久免费免熟 | 国产av一区二区三区传媒 | 国产乱人乱偷精品视频a人人澡 | 日日爱av | 国产精品无码av在线有声小说 | 96日本xxxxxⅹxxx17| 北条麻妃av在线 | 大奶一区二区 | 黄色福利视频网站 | 国产高清久久久 | 中文字幕一区在线观看 | 美女视频黄的免费 | 欧美日韩中文在线视频 | 九色91| 貂蝉被到爽流白浆在线观看 | 午夜在线不卡 | 成人xxx| 欧美日韩一区二区在线观看视频 | 日本精品在线观看 | 免费黄色网址在线观看 | 国久久| 日韩精品一区二区三区四区 | av女优一区 | 美国爱爱视频 | 久久成人久久爱 | 欧美一区二区三区黄片 | 日本理论片午伦夜理片在线观看 | 国产一卡在线 | 欧美噜噜噜 | 美女被叉叉的影院 | 久草这里只有精品 |