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

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

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

python logging模塊及日志定時清理

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時使用
  • INFO:程序正常運行時使用
  • WARNING:程序未按預(yù)期運行時使用,但并不是錯誤,如:用戶登錄密碼錯誤
  • ERROR:程序出錯誤時使用,如:IO操作失敗
  • CRITICAL:特別嚴重的問題,導(dǎo)致程序不能再繼續(xù)運行時使用,如:磁盤空間為空,一般很少使用

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

3.常用handlers的使用

StreamHandler

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

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

只有一個參數(shù):

class logging.StreamHandler(stream=None)

日志信息會輸出到指定的stream中,如果stream為空則默認輸出到sys.stderr。

FileHandler

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

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

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

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

NullHandler

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

WatchedFileHandler

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

這個handler是專門為linux/unix系統(tǒng)設(shè)計的,因為在windows系統(tǒng)下,正在被打開的文件是不會被改變的。

參數(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允許日志文件在達到maxBytes時rollover.當(dāng)文件大小達到或者超過maxBytes時,就會新創(chuàng)建一個日志文件。

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

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

TimedRotatingFileHandler

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

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

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

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

超過數(shù)量就會丟棄掉老的日志文件。when的參數(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:是一個字符串,用于描述滾動周期的基本單位,字符串的值及意義如下(不區(qū)分大小寫):
類型單位
S
M
H
D
W0-W6周一至周日
midnight每天的凌晨
  • interval: 滾動周期,單位有when指定,比如:when=’D’,interval=1,表示每天產(chǎn)生一個日志文件,且清理匹配到的過期文件;
  • backupCount: 表示日志文件的保留個數(shù);
  • delay:延遲文件創(chuàng)建,直到第一次調(diào)用emit()方法創(chuàng)建日志文件
  • atTime:在指定的時間(datetime.time格式)創(chuàng)建日志文件。

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

# suffix設(shè)置,會生成文件名為xxx.2022-02-10.log
log_file_handler.suffix = "%Y-%m-%d.log"  
# extMatch是編譯好正則表達式,用于匹配日志文件名后綴,需要注意的是suffix和extMatch一定要匹配的上,如果不匹配,過期日志不會被刪除。
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é)

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

相關(guān)文章

  • 簡單介紹Python中的RSS處理

    簡單介紹Python中的RSS處理

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

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

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

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

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

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

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

    python+matplotlib演示電偶極子實例代碼

    這篇文章主要介紹了python+matplotlib演示電偶極子實例代碼,具有一定借鑒價值,需要的朋友可以參考下
    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)表達式的真值已經(jīng)確定時終止布爾運算,Python 解釋器以從左到右的方式計算表達式,這篇文章主要介紹了Python 中的短路評估,需要的朋友可以參考下
    2023-06-06
  • 詳解Python迭代和迭代器

    詳解Python迭代和迭代器

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

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

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

    Python編解碼16進制碼流的示例代碼

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

最新評論