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

Python之打印日志庫(logging)

 更新時間:2023年09月13日 16:57:26   作者:hopyGreat  
這篇文章主要介紹了Python之打印日志庫(logging),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

一、日志等級

級別何時使用
DEBUG細(xì)節(jié)信息,僅當(dāng)診斷問題時使用
INFO確認(rèn)程序按預(yù)期運行
WARNING表明已經(jīng)或即將發(fā)生的意外(例如:磁盤空間不足)。程序仍按預(yù)期進(jìn)行
ERROR由于嚴(yán)重的問題,程序的某些功能已經(jīng)不能正常執(zhí)行
CRITICAL嚴(yán)重的錯誤,表明程序已不能繼續(xù)執(zhí)行

默認(rèn)等級是“WARNING”,意味著只會跟蹤該級別及以上的事件(由上倒下等級以此遞增),除非更改日志配置。

二、基本用法

1. quick start

>>> import logging
>>> logging.warning("warning")
WARNING:root:warning
>>> logging.info("information")
>>>

注意這里只有warning的信息打印出來了。如前面所說,默認(rèn)等級是“WARNING”,只會追蹤該級別及以上的事件,所以info信息沒有被打印出來。

其中WARNING是記錄級別;root代表打印的模塊來源(沒有顯示設(shè)置,顯然是默認(rèn)值,甚至不是當(dāng)前模塊的名稱);warning就是我們顯示打印的數(shù)據(jù)信息了。

2. 記錄日志到文件

import logging
logging.basicConfig(filename='pycode.log', level=logging.DEBUG)
logging.warning('warning')
logging.info('information')
logging.debug('debug')

通過設(shè)置logging的基本配置可以將記錄重定向到文件中。同時可以通過level指定打印級別。

# pycode.log
WARNING:root:warning
INFO:root:information
DEBUG:root:debug

注意到,此時在文件中的打印級別已經(jīng)降為 DEBUG了。該方法也適用在命令行中修改打印級別。

但有個需要注意的點:對basicConfig的調(diào)用應(yīng)該在debug(),info()等函數(shù)前面。basicConfig是一次性的配置,只有第一次調(diào)用會進(jìn)行操作,隨后的調(diào)用不會產(chǎn)生有效操作。

什么意思呢?

舉個例子:

>>> import logging
>>> logging.warning("123")
WARNING:root:123
>>> logging.info("123") # 不會有輸出
>>> logging.basicConfig(level=logging.DEBUG)
>>> logging.info("123") # 依舊不會有輸出

另一個例子:

>>> import logging
>>> logging.basciConfig(level=loggin.DEBUG)
>>> logging.warning("123")
WARNING:root:123
>>> logging.info("123")
INFO:root:123

在第一次調(diào)用logging.info()、warning()等函數(shù)的時候,就會調(diào)用內(nèi)置的basicConfig。此時就已經(jīng)固化打印級別為WARNING了,即使后面再次顯式調(diào)用basicConfig也不會有效。 

命令行指定級別:除了通過basicConfig設(shè)置level,也可以在執(zhí)行Python程序的時候,通過命令行參數(shù)指定。

$ 設(shè)置logging打印級別為INFO 
$ python3 pycode.py --log=INFO

追加打印:此外,記錄輸出到文件中,默認(rèn)是追加打印的。如果希望重新記錄,可以這樣:

logging.basicConfig(filename='pycode.log', filemode='w', level=logging.DEBUG)

3. 多模塊打印 

# main.py
import logging
import somelib
logging.basicConfig(level=logging.INFO)
def main():
    logging.info("py01")
    py02.do_something()
if __name__ == '__main__':
    main()
# ---------------------------
# somelib.py
import logging
def do_something():
    logging.info("py02")

輸出:

# pycode.log
INFO:root:py01
INFO:root:py02

可以看到,多模塊的信息都能正常打印到日志文件中。但很明顯可以發(fā)現(xiàn)不論是從哪個模塊輸出,日志記錄中顯示的都是root。所以目前還不能跟蹤記錄打印的模塊來源。

4. 定義打印格式

前面出現(xiàn)的打印信息基本上是:記錄級別:模塊來源:記錄信息

同樣可以在basicConfig中定義打印的格式:

>>> import logging
>>> logging.basicConfig(format='%(asctime)s : %(name)s : %(message)s', level=logging.INFO)
>>> logging.info("123")
2020-06-19 22:38:16,048 : root : 123

可以看到,此時展示了打印時間,模塊來源及記錄信息。

格式配置屬性:

格式描述
%(asctime)s調(diào)用消息記錄打印時的時間(格式化后的時間)
%(created)f調(diào)用消息記錄打印時的時間(未格式化的描述,相當(dāng)于time.time())
%(filename)s調(diào)用消息記錄打印的文件名稱(在哪個文件里面)
%(funcName)s調(diào)用消息記錄打印的函數(shù)名稱(在哪個函數(shù)里面)
%(levelname)s消息記錄級別(DEBUG,INFO,WARNING,ERROR,CRITICAL)
%(levelno)s消息記錄級別的數(shù)字號(DEBUG=10,INFO=20,WARNING=30,ERROR=40,CRITICAL=50)
%(lineno)d調(diào)用消息記錄打印的行數(shù)(在哪一行打印的)
%(message)s待打印的自定義消息
%(module)s調(diào)用消息記錄的模塊名
%(msecs)d調(diào)用消息記錄打印時間的毫秒部分
%(name)s打印消息的logger對象名稱(自定義的,默認(rèn)是root)
%(pathname)s調(diào)用消息記錄的文件路徑
%(process)d進(jìn)程ID
%(processName)s進(jìn)程名
%(relativeCreated)d相對logging模塊被加載到打印消息記錄時的相對時間(毫秒)
%(thread)d線程ID
%(threadName)s線程名

此時,為了跟蹤打印消息的來源,我們可以組織一個這樣的格式串:

# main.py
import logging
import somelib
logging.basicConfig(
    level=logging.INFO,
    format="%(asctime)s: %(name)s: %(levelname)s: %(message)s")
logger = logging.getLogger("main123")
def main():
    logger.info("py01")
    somelib.do_something()
if __name__ == '__main__':
    main()
# ------------------------------
# somelib.py
import logging
logger = logging.getLogger("pylib")
def do_something():
    logger.info("py02")
# ------------------------------
# 輸出
2020-06-19 23:26:27,263: main123: INFO: py01
2020-06-19 23:26:27,264: pylib: INFO: py02

有其他的需求,也可以根據(jù)上面列出來的屬性自行搭配。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 利用python?制作詞云特效詳情

    利用python?制作詞云特效詳情

    這篇文章主要介紹了利用python?制作詞云特效詳情,?詞云?也是數(shù)據(jù)可視化的一種形,根據(jù)關(guān)鍵詞的出現(xiàn)頻率而生成的一幅圖像,人們只要掃一眼就能夠明白其文章主旨,下文詳細(xì)介紹,需要的朋友可以參考一下
    2022-04-04
  • Python之tkinter組合框Combobox用法及說明

    Python之tkinter組合框Combobox用法及說明

    這篇文章主要介紹了Python之tkinter組合框Combobox用法及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Python遞歸時間復(fù)雜度

    Python遞歸時間復(fù)雜度

    這篇文章主要介紹了Python遞歸時間復(fù)雜度,時間復(fù)雜度一般認(rèn)為O(logn),但遞歸算法的時間復(fù)雜度本質(zhì)上是要看遞歸的次數(shù),每次遞歸中的操作次數(shù),下面文章詳細(xì)介紹,需要的朋友可以參考一下
    2022-03-03
  • Pytorch?nn.Dropout的用法示例詳解

    Pytorch?nn.Dropout的用法示例詳解

    這篇文章主要介紹了Pytorch?nn.Dropout的用法,本文通過示例代碼介紹的非常詳細(xì),文中補充介紹了torch.nn.dropout和torch.nn.dropout2d的區(qū)別,需要的朋友可以參考下
    2023-04-04
  • Python程序退出方式小結(jié)

    Python程序退出方式小結(jié)

    這篇文章主要介紹了Python程序退出方式小結(jié),具有一定參考價值,需要的朋友可以了解下。
    2017-12-12
  • python實現(xiàn)LRU熱點緩存及原理

    python實現(xiàn)LRU熱點緩存及原理

    LRU算法根據(jù)數(shù)據(jù)的歷史訪問記錄來進(jìn)行淘汰數(shù)據(jù),其核心思想是“如果數(shù)據(jù)最近被訪問過,那么將來被訪問的幾率也更高”。 。這篇文章主要介紹了python實現(xiàn)LRU熱點緩存,需要的朋友可以參考下
    2019-10-10
  • Python如何實現(xiàn)的簡單購物車程序

    Python如何實現(xiàn)的簡單購物車程序

    這篇文章主要介紹了Python如何實現(xiàn)的簡單購物車程序,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下
    2021-05-05
  • 淺談Keras中fit()和fit_generator()的區(qū)別及其參數(shù)的坑

    淺談Keras中fit()和fit_generator()的區(qū)別及其參數(shù)的坑

    這篇文章主要介紹了Keras中fit()和fit_generator()的區(qū)別及其參數(shù)的坑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • Python搭建代理IP池實現(xiàn)獲取IP的方法

    Python搭建代理IP池實現(xiàn)獲取IP的方法

    這篇文章主要介紹了Python搭建代理IP池實現(xiàn)獲取IP的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Django ORM實現(xiàn)按天獲取數(shù)據(jù)去重求和例子

    Django ORM實現(xiàn)按天獲取數(shù)據(jù)去重求和例子

    這篇文章主要介紹了Django ORM實現(xiàn)按天獲取數(shù)據(jù)去重求和例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05

最新評論