亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

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

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

接下來我們來學習怎么使用loguru模塊進行日志管理。

安裝

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

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級別日志")

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

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

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

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

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

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

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

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

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

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

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

filter:過濾日志。

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

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

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

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

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

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

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

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

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

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

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

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

compression:配置文件壓縮格式。

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

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

使用

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

from loguru import logger
import sys
# format建議直接使用默認的格式
logger.add("../log/test_{time}.log", level="INFO", encoding="utf-8", enqueue=True, rotation="500MB", retention="1 week")
# 當然也可以自定義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文件時名稱會加上時間。
  • level="INFO",寫入文件時只會寫入INFO及以上級別的日志 (需要大寫),即INFO、WARNING、CRITICAL。
  • encoding="utf-8",日志寫入文件時指定編碼格式為"utf-8",否則有中文的話會顯示亂碼。
  • enqueue=True,支持多線程多進程執(zhí)行時按照隊列寫入。
  • rotation="500MB",日志文件最大為500MB,超過則新建。
  • retention="1 week",日志保留一周,過后則清除。
  • format沒有指定即使用默認格式,建議直接使用默認的格式,見代碼注釋。

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

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

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

相關(guān)文章

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

    分享給Python新手們的幾道簡單練習題

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

最新評論