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

python?logging模塊詳解及其日志定時(shí)清理方式

 更新時(shí)間:2025年04月16日 14:40:22   作者:小白、瑤  
這篇文章主要介紹了python?logging模塊詳解及其日志定時(shí)清理方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

python logging模塊及日志定時(shí)清理

1.創(chuàng)建logger對象

logger = logging.getLogger(log_name) # 傳入logger名字

2.logging.basicConfig常用樣式

logging.basicConfig(level=logging.DEBUG,
                    format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
                    datefmt='%a, %d %b %Y %H:%M:%S',
                    filename='./Log/test_log.log',
                    filemode='a')
參數(shù)名稱描述
level日志輸出級別
format日志輸出的格式
datefmt使用指定的格式字符串的處理程序
filename日志輸出到文件的文件名
filemode文件模式,r[+]、w[+]、a[+]

日志等級說明:

  • DEBUG:程序調(diào)試bug時(shí)使用
  • INFO:程序正常運(yùn)行時(shí)使用
  • WARNING:程序未按預(yù)期運(yùn)行時(shí)使用,但并不是錯(cuò)誤,如:用戶登錄密碼錯(cuò)誤
  • ERROR:程序出錯(cuò)誤時(shí)使用,如:IO操作失敗
  • CRITICAL:特別嚴(yán)重的問題,導(dǎo)致程序不能再繼續(xù)運(yùn)行時(shí)使用,如:磁盤空間為空,一般很少使用

日志等級從低到高的順序是: DEBUG < INFO < WARNING < ERROR < CRITICAL

3.常用handlers的使用

StreamHandler

流handler——包含在logging模塊中的三個(gè)handler之一。

能夠?qū)⑷罩拘畔⑤敵龅絪ys.stdout, sys.stderr 或者類文件對象(更確切點(diǎn),就是能夠支持write()和flush()方法的對象)。

只有一個(gè)參數(shù):

class logging.StreamHandler(stream=None)

日志信息會(huì)輸出到指定的stream中,如果stream為空則默認(rèn)輸出到sys.stderr。

FileHandler

logging模塊自帶的三個(gè)handler之一。繼承自StreamHandler。將日志信息輸出到磁盤文件上。

構(gòu)造參數(shù):

class logging.FileHandler(filename, mode='a', encoding=None, delay=False)

模式默認(rèn)為append,delay為true時(shí),文件直到emit方法被執(zhí)行才會(huì)打開。默認(rèn)情況下,日志文件可以無限增大。

NullHandler

空操作handler,logging模塊自帶的三個(gè)handler之一。沒有參數(shù)。

WatchedFileHandler

位于logging.handlers模塊中。用于監(jiān)視文件的狀態(tài),如果文件被改變了,那么就關(guān)閉當(dāng)前流,重新打開文件,創(chuàng)建一個(gè)新的流。由于newsyslog或者logrotate的使用會(huì)導(dǎo)致文件改變。

這個(gè)handler是專門為linux/unix系統(tǒng)設(shè)計(jì)的,因?yàn)樵趙indows系統(tǒng)下,正在被打開的文件是不會(huì)被改變的。

參數(shù)和FileHandler相同:

class logging.handlers.WatchedFileHandler(filename, mode='a', encoding=None, delay=False)

RotatingFileHandler

位于logging.handlers支持循環(huán)日志文件。

class logging.handlers.RotatingFileHandler(filename, mode='a', maxBytes=0, backupCount=0, encoding=None, delay=0)

參數(shù)maxBytes和backupCount允許日志文件在達(dá)到maxBytes時(shí)rollover.當(dāng)文件大小達(dá)到或者超過maxBytes時(shí),就會(huì)新創(chuàng)建一個(gè)日志文件。

上述的這兩個(gè)參數(shù)任一一個(gè)為0時(shí),rollover都不會(huì)發(fā)生。也就是就文件沒有maxBytes限制。backupcount是備份數(shù)目,也就是最多能有多少個(gè)備份。

當(dāng)前的日志文件大小超過設(shè)定的maxBytes時(shí)會(huì)將當(dāng)前的日志文件名例a.log后面加上.1的后綴,如a.log.1,并新建一個(gè)a.log文件來記錄日志信息。

TimedRotatingFileHandler

定時(shí)循環(huán)日志handler,位于logging.handlers,支持定時(shí)生成新日志文件。

class logging.handlers.TimedRotatingFileHandler(filename, when='h', interval=1, backupCount=0, encoding=None, delay=False, utc=False)

參數(shù)when決定了時(shí)間間隔的類型,參數(shù)interval決定了多少的時(shí)間間隔。

如when=‘D’,interval=2,就是指兩天的時(shí)間間隔,backupCount決定了能留幾個(gè)日志文件。

超過數(shù)量就會(huì)丟棄掉老的日志文件。when的參數(shù)決定了時(shí)間間隔的類型。

其他handler

SocketHandler、DatagramHandler、SysLogHandler、NtEventHandler、SMTPHandler、MemoryHandler、HTTPHandler

這些handler都不怎么常用,所以具體介紹就請參考官方文檔 其他handlers

handler參數(shù)配置

如:

class logging.handlers.TimedRotatingFileHandler(filename, when='h', interval=1, backupCount=0, encoding=None, delay=False, utc=False)
  • when:是一個(gè)字符串,用于描述滾動(dòng)周期的基本單位,字符串的值及意義如下(不區(qū)分大小寫):
類型單位
S
M
H時(shí)
D
W0-W6周一至周日
midnight每天的凌晨
  • interval: 滾動(dòng)周期,單位有when指定,比如:when=’D’,interval=1,表示每天產(chǎn)生一個(gè)日志文件,且清理匹配到的過期文件;
  • backupCount: 表示日志文件的保留個(gè)數(shù);
  • delay:延遲文件創(chuàng)建,直到第一次調(diào)用emit()方法創(chuàng)建日志文件
  • atTime:在指定的時(shí)間(datetime.time格式)創(chuàng)建日志文件。

刪除日志文件設(shè)置

# suffix設(shè)置,會(huì)生成文件名為xxx.2022-02-10.log
log_file_handler.suffix = "%Y-%m-%d.log"  
# extMatch是編譯好正則表達(dá)式,用于匹配日志文件名后綴,需要注意的是suffix和extMatch一定要匹配的上,如果不匹配,過期日志不會(huì)被刪除。
log_file_handler.extMatch = re.compile(r"^\d{4}-\d{2}-\d{2}.log$")

suffix和extMatch的格式要相對應(yīng),Year-4位,m-2位 以此類推

舉例:

rf_handler = logging.handlers.TimedRotatingFileHandler('all.log', when='midnight', interval=1, backupCount=7, atTime=datetime.time(0, 0, 0, 0))
rf_handler.setFormatter(logging.Formatter("[%(asctime)s] -- %(remote_addr)s -- requested -- %(url)s -- %(levelname)s -- %(process)s -- %(thread)s -- %(module)s -- %(funcName)s -- %(lineno)d -- %(message)s --\n__________"))

添加到日志處理對象集合

my_logging.addHandler(handle)

關(guān)閉日志收集器

my_logging.removeHandler(handler)

總結(jié)

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

相關(guān)文章

  • 簡單介紹Python中的RSS處理

    簡單介紹Python中的RSS處理

    這篇文章主要介紹了簡單介紹Python中的RSS處理,本文來自于IBM官方開發(fā)者技術(shù)文檔,需要的朋友可以參考下
    2015-04-04
  • Python pyinstaller庫的安裝配置教程分享

    Python pyinstaller庫的安裝配置教程分享

    pyinstaller模塊主要用于python代碼打包成exe程序直接使用,這樣在其它電腦上即使沒有python環(huán)境也是可以運(yùn)行的。本文就來和大家分享一下pyinstaller庫的安裝配置教程,希望對大家有所幫助
    2023-04-04
  • Python編程django實(shí)現(xiàn)同一個(gè)ip十分鐘內(nèi)只能注冊一次

    Python編程django實(shí)現(xiàn)同一個(gè)ip十分鐘內(nèi)只能注冊一次

    這篇文章主要介紹了Python編程django實(shí)現(xiàn)同一個(gè)ip十分鐘內(nèi)只能注冊一次的相關(guān)內(nèi)容,具有一定參考價(jià)值。需要的朋友可以了解下。
    2017-11-11
  • PyTorch中tensor.backward()函數(shù)的詳細(xì)介紹及功能實(shí)現(xiàn)

    PyTorch中tensor.backward()函數(shù)的詳細(xì)介紹及功能實(shí)現(xiàn)

    backward()?函數(shù)是PyTorch框架中自動(dòng)求梯度功能的一部分,它負(fù)責(zé)執(zhí)行反向傳播算法以計(jì)算模型參數(shù)的梯度,這篇文章主要介紹了PyTorch中tensor.backward()函數(shù)的詳細(xì)介紹,需要的朋友可以參考下
    2024-02-02
  • python+matplotlib演示電偶極子實(shí)例代碼

    python+matplotlib演示電偶極子實(shí)例代碼

    這篇文章主要介紹了python+matplotlib演示電偶極子實(shí)例代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-01-01
  • Python中的?pass?占位語句

    Python中的?pass?占位語句

    這篇文章主要介紹了Python中的?pass?占位語句,Python?pass是空語句,是為了保持程序結(jié)構(gòu)的完整性,下文具體的相關(guān)內(nèi)容介紹需要的小伙伴可以參考一下
    2022-04-04
  • 詳解Python 中的短路評估

    詳解Python 中的短路評估

    短路是指當(dāng)表達(dá)式的真值已經(jīng)確定時(shí)終止布爾運(yùn)算,Python 解釋器以從左到右的方式計(jì)算表達(dá)式,這篇文章主要介紹了Python 中的短路評估,需要的朋友可以參考下
    2023-06-06
  • 詳解Python迭代和迭代器

    詳解Python迭代和迭代器

    這篇文章主要為大家詳細(xì)介紹了Python迭代和迭代器,感興趣的小伙伴們可以參考一下
    2016-03-03
  • Python面向?qū)ο笾惡蛯ο髮傩缘脑鰟h改查操作示例

    Python面向?qū)ο笾惡蛯ο髮傩缘脑鰟h改查操作示例

    這篇文章主要介紹了Python面向?qū)ο笾惡蛯ο髮傩缘脑鰟h改查操作,結(jié)合實(shí)例形式分析了Python面向?qū)ο笙嚓P(guān)的類與對象屬性常見操作技巧,需要的朋友可以參考下
    2018-12-12
  • Python編解碼16進(jìn)制碼流的示例代碼

    Python編解碼16進(jìn)制碼流的示例代碼

    這篇文章主要為大家詳細(xì)介紹了Python編解碼16進(jìn)制碼流的相關(guān)資料,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-04-04

最新評論