欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python+pytest接口自動化之日志管理模塊loguru簡介

 更新時(shí)間:2022年05月06日 09:07:26   作者:給你一頁白紙  
python中有一個(gè)用起來非常簡便的第三方日志管理模塊--loguru,不僅可以避免logging的繁瑣配置,而且可以很簡單地避免在logging中多進(jìn)程多線程記錄日志時(shí)出現(xiàn)的問題,甚至還可以自定義控制臺輸出的日志顏色,接下來我們來學(xué)習(xí)怎么使用loguru模塊進(jìn)行日志管理

python自帶日志管理模塊logging,使用時(shí)可進(jìn)行模塊化配置,詳細(xì)可參考博文Python日志采集(詳細(xì))

logging配置起來比較繁瑣,且在多進(jìn)行多線程等場景下使用時(shí),如果不經(jīng)過特殊處理,則容易出現(xiàn)日志丟失或記錄錯(cuò)亂的情況。

python中有一個(gè)用起來非常簡便的第三方日志管理模塊--loguru,不僅可以避免logging的繁瑣配置,而且可以很簡單地避免在logging中多進(jìn)程多線程記錄日志時(shí)出現(xiàn)的問題,甚至還可以自定義控制臺輸出的日志顏色。

接下來我們來學(xué)習(xí)怎么使用loguru模塊進(jìn)行日志管理。

安裝

第三方模塊,需要先安裝,安裝命令如下:

pip install loguru

簡單示例

簡單使用示例如下:

from loguru import logger
# 日志寫入文件則需使用add()方法,"../log/test.log"即日志文件路徑,可自定義。
# 寫入文件的日志里有中文的話,需要加上encoding="utf-8",否則會顯示亂碼。
logger.add("../log/test.log", encoding="utf-8", rotation="500MB",
           enqueue=True, retention="7 days")
# 打印不同類型的日志
logger.debug("這是一段debug級別日志")
logger.info("這是一段info級別日志")
logger.warning("這是一段warning級別日志")
logger.critical("這是一段critical級別日志")

上面的示例代碼運(yùn)行之后,會在控制臺打印如下日志:

同時(shí)也會在 "../log/test.log" 路徑中寫入日志,如下:

由以上結(jié)果可以看出:

  • loguru中直接提供了一個(gè)日志記錄對象logger,拿來即用;
  • loguru默認(rèn)的輸出格式為:時(shí)間 | 級別 | 模塊名 | 行號 | 日志信息;
  • 不同級別的日志在控制臺顯示顏色不一樣。

當(dāng)然,在實(shí)際項(xiàng)目中我們還需要日志管理器有更豐富的配置,loguru中的add()方法便具有強(qiáng)大的配置功能,接下來介紹add()方法提供的常用配置功能。

add()常用參數(shù)說明

loguru模塊源碼中add()方法的參數(shù)如下:

sink(官方文檔簡單翻譯如下):

  • 可以傳入類file對象,如sys.stderr或者open('test.log', 'w')
  • 可以傳入文件路徑strpathlib,如示例代碼中的寫入日志文件路徑。路徑可以使用一些附加參數(shù)對其進(jìn)行參數(shù)化,如test_{time}.log,{time}即時(shí)間參數(shù),創(chuàng)建文件時(shí)文件名稱中會加入時(shí)間。
  • 可以傳入像lambda這樣的可調(diào)用函數(shù)的簡單函數(shù),如lambda msg:print(msg)。這允許完全由用戶偏好和需求定義日志記錄過程。
  • 還可以是使用async def語句定義的異步協(xié)程函數(shù)。該函數(shù)返回的協(xié)程對象將使用loop.create_task()添加到事件循環(huán)中。在使用complete()結(jié)束循環(huán)之前,應(yīng)該等待這些任務(wù)。
  • 也支持傳入logging模塊的Handler,如FileHandlerStreamHandler等,Loguru記錄會自動轉(zhuǎn)換為日志模塊預(yù)期的結(jié)構(gòu)。

level:發(fā)送到sink的日志消息的最低日志級別,即輸出的最低日志級別。

format:定義日志的輸出格式。

filter:過濾日志。

colorize:終端日志輸出的顏色。

serializer:bool值,輸出日志時(shí)是否先格式化成JSON數(shù)據(jù)格式。

backtrace:bool值,是否進(jìn)行異常跟蹤(即backtrace信息記錄)。

diagnose:bool值,異常跟蹤是否應(yīng)顯示變量值以簡化調(diào)試。在生產(chǎn)中應(yīng)將其設(shè)置為False,以避免泄漏敏感數(shù)據(jù)。

enqueue:bool值,日志消息輸出之前是否先通過多進(jìn)程安全隊(duì)列,多進(jìn)程多線程運(yùn)行寫入日志時(shí)需用到,避免日志記錄丟失或混亂。

catch:bool值,是否自動捕獲接收器處理日志消息時(shí)發(fā)生的錯(cuò)誤。如果為True,則在sys上顯示異常消息。

繼續(xù)看loguru模塊源碼,如下:

即我們需要將日志寫入指定的文件時(shí),可以使用截圖中新增的參數(shù)。常用的參數(shù)說明如下:

rotation:指定日志文件記錄條件,日志輸出太多需要隔一段時(shí)間寫入新文件時(shí)適用。

# rotation指定日志文件最大為500MB,超過則新建文件記錄日志
logger.add("../log/test.log", rotation="500MB")
# 指定每天12:00新建日志記錄文件:rotation="12:00"
# 指定每隔10天新建日志記錄文件:rotation="10 days"
# 指定每隔一個(gè)星期新建日志記錄文件:rotation="1 week"
# 指定每隔兩個(gè)月新建日志記錄文件:rotation="2 months"

retention:指定日志保留時(shí)長,會清除超過指定時(shí)長的數(shù)據(jù)。

# rotation指定日志保留時(shí)長,如"1 week", "3 days", "2 months"
logger.add("../log/test.log", retention="10 days")

compression:配置文件壓縮格式。

# rotation指定日志保留時(shí)長,如"gz", "bz2", "xz", "lzma", "tar", "tar.gz", "tar.bz2", "tar.xz", "zip"
logger.add("../log/test.log", compression="zip")

encoding:指定寫入文件時(shí)的編碼格式,這在示例代碼中已說明。

使用

接下來,我們使用常用的參數(shù)來組合定義日志記錄方式。

from loguru import logger
import sys
# format建議直接使用默認(rèn)的格式
logger.add("../log/test_{time}.log", level="INFO", encoding="utf-8", enqueue=True, rotation="500MB", retention="1 week")
# 當(dāng)然也可以自定義format,如下示例
# logger.add("../log/test_{time}.log", 
			format="{time:YYYY-MM-DD HH:mm:ss} | {level} | {name} | {line} | {message}", encoding="utf-8", 				enqueue=True, rotation="500MB", retention="1 week")
# 打印不同類型的日志
logger.debug("這是一段debug級別日志")
logger.info("這是一段info級別日志")
logger.warning("這是一段warning級別日志")
logger.critical("這是一段critical級別日志")

參數(shù)說明:

  • sink="../log/test_{time}.log",即指定日志文件路徑,且加入了{time},創(chuàng)建.log文件時(shí)名稱會加上時(shí)間。
  • level="INFO",寫入文件時(shí)只會寫入INFO及以上級別的日志 (需要大寫),即INFO、WARNING、CRITICAL。
  • encoding="utf-8",日志寫入文件時(shí)指定編碼格式為"utf-8",否則有中文的話會顯示亂碼。
  • enqueue=True,支持多線程多進(jìn)程執(zhí)行時(shí)按照隊(duì)列寫入。
  • rotation="500MB",日志文件最大為500MB,超過則新建。
  • retention="1 week",日志保留一周,過后則清除。
  • format沒有指定即使用默認(rèn)格式,建議直接使用默認(rèn)的格式,見代碼注釋。

執(zhí)行代碼后,結(jié)果如下:

從結(jié)果中可以看出來,輸出內(nèi)容中模塊部分顯示的是如__main__:<module>:20的形式,而并不是我們想要看到的對應(yīng)的模塊名稱,這是因?yàn)橹苯訄?zhí)運(yùn)行了當(dāng)前文件的文件,如果是其他模塊調(diào)用執(zhí)行便會顯示對應(yīng)的模塊名稱。

到此這篇關(guān)于python+pytest接口自動化(15)-日志管理模塊loguru簡介的文章就介紹到這了,更多相關(guān)python日志管理模塊loguru內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 分享給Python新手們的幾道簡單練習(xí)題

    分享給Python新手們的幾道簡單練習(xí)題

    這篇文章主要給學(xué)習(xí)Python的新手們分享了幾道簡單練習(xí)題,文中給出了詳細(xì)的示例代碼供大家學(xué)習(xí)參考,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-09-09
  • python 實(shí)現(xiàn)人和電腦猜拳的示例代碼

    python 實(shí)現(xiàn)人和電腦猜拳的示例代碼

    這篇文章主要介紹了python 實(shí)現(xiàn)人和電腦猜拳的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • Python中猜拳游戲與猜篩子游戲的實(shí)現(xiàn)方法

    Python中猜拳游戲與猜篩子游戲的實(shí)現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于Python中猜拳游戲與猜篩子游戲的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • Python優(yōu)雅處理日志記錄的方法小結(jié)

    Python優(yōu)雅處理日志記錄的方法小結(jié)

    日志記錄在軟件開發(fā)中扮演著至關(guān)重要的角色,它不僅可以幫助開發(fā)人員跟蹤應(yīng)用程序的狀態(tài)和行為,還能提供有價(jià)值的診斷信息,本文將深入探討?Python?中優(yōu)雅處理日志的方法,文中有詳細(xì)的代碼示例供大家參考,需要的朋友可以參考下
    2023-12-12
  • Python 實(shí)現(xiàn)12306登錄功能實(shí)例代碼

    Python 實(shí)現(xiàn)12306登錄功能實(shí)例代碼

    這篇文章主要介紹了Python 實(shí)現(xiàn)12306登錄功能的完整代碼,需要的朋友可以參考下
    2018-02-02
  • 對Python發(fā)送帶header的http請求方法詳解

    對Python發(fā)送帶header的http請求方法詳解

    今天小編就為大家分享一篇對Python發(fā)送帶header的http請求方法詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • Python實(shí)現(xiàn)將SQLite中的數(shù)據(jù)直接輸出為CVS的方法示例

    Python實(shí)現(xiàn)將SQLite中的數(shù)據(jù)直接輸出為CVS的方法示例

    這篇文章主要介紹了Python實(shí)現(xiàn)將SQLite中的數(shù)據(jù)直接輸出為CVS的方法,涉及Python連接、讀取SQLite數(shù)據(jù)庫及轉(zhuǎn)換CVS格式數(shù)據(jù)的相關(guān)操作技巧,需要的朋友可以參考下
    2017-07-07
  • Python趣味實(shí)例,實(shí)現(xiàn)一個(gè)簡單的抽獎刮刮卡

    Python趣味實(shí)例,實(shí)現(xiàn)一個(gè)簡單的抽獎刮刮卡

    這篇文章主要介紹了Python如何實(shí)現(xiàn)一個(gè)簡單的抽獎刮刮卡,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • python爬蟲框架scrapy實(shí)現(xiàn)模擬登錄操作示例

    python爬蟲框架scrapy實(shí)現(xiàn)模擬登錄操作示例

    這篇文章主要介紹了python爬蟲框架scrapy實(shí)現(xiàn)模擬登錄操作,結(jié)合實(shí)例形式分析了scrapy框架實(shí)現(xiàn)模擬登陸操作的步驟、相關(guān)實(shí)現(xiàn)技巧與注意事項(xiàng),需要的朋友可以參考下
    2018-08-08
  • 教你用scrapy框架爬取豆瓣讀書Top250的書類信息

    教你用scrapy框架爬取豆瓣讀書Top250的書類信息

    這篇文章主要介紹了教你用scrapy框架爬取豆瓣讀書Top250的書類信息,文中提供了解決思路和部分實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2023-03-03

最新評論