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

python通過TimedRotatingFileHandler按時(shí)間切割日志

 更新時(shí)間:2019年07月17日 16:11:48   作者:學(xué)一點(diǎn)也是好  
這篇文章主要介紹了python通過TimedRotatingFileHandler按時(shí)間切割日志的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

通過TimedRotatingFileHandler按時(shí)間切割日志

線上跑了一個(gè)定時(shí)腳本,每天生成的日志文件都寫在了一個(gè)文件中。但是日志信息不可能輸出到單一的一個(gè)文件中。

原因有二:1.日志文件越來越大會(huì)影響系統(tǒng)的性能。2.日志文件格式不夠清晰,比如我想看今天的日志,不太方便找到的今天的日志信息(即使對(duì)日志輸出做了時(shí)間提示)

通過設(shè)置 TimedRotatingFileHandler 進(jìn)行日志按周(W)、天(D)、時(shí)(H)、分(M)、秒(S)切割。

先看一個(gè)簡(jiǎn)單例子:

import time
import logging
import os
from logging import handlers
def _logging(**kwargs):
  level = kwargs.pop('level', None)
  filename = kwargs.pop('filename', None)
  datefmt = kwargs.pop('datefmt', None)
  format = kwargs.pop('format', None)
  if level is None:
    level = logging.DEBUG
  if filename is None:
    filename = 'default.log'
  if datefmt is None:
    datefmt = '%Y-%m-%d %H:%M:%S'
  if format is None:
    format = '%(asctime)s [%(module)s] %(levelname)s [%(lineno)d] %(message)s'
  log = logging.getLogger(filename)
  format_str = logging.Formatter(format, datefmt)
  # backupCount 保存日志的數(shù)量,過期自動(dòng)刪除
  # when 按什么日期格式切分(這里方便測(cè)試使用的秒)
  th = handlers.TimedRotatingFileHandler(filename=filename, when='S', backupCount=3, encoding='utf-8')
  th.setFormatter(format_str)
  th.setLevel(logging.INFO)
  log.addHandler(th)
  log.setLevel(level)
  return log
os.makedirs("./logs", exist_ok=True)
logger = _logging(filename='./logs/default.log')
if __name__ == '__main__':
  while True:
    time.sleep(0.1)
    logger.info('哈哈哈')

結(jié)果如下:

上述代碼可以正常運(yùn)行,而且也可以生成固定的日志個(gè)數(shù),但是有一個(gè)問題,生成的日志文件格式是你的 文件名+時(shí)間 的格式,沒有設(shè)置時(shí)間的話默認(rèn)設(shè)置到了秒(這里是按秒切割)

修改日志格式后綴名稱:

# 在上述代碼中加入
def namer(filename):
  return filename.split('default.')
th.namer = namer
# 設(shè)置為S,默認(rèn)的suffix為 Y-%m-%d_%H-%M-%S
th.suffix = "%Y-%m-%d_%H-%M-%S.log"
# 為了看的更視覺效果,可以顯示在控制臺(tái)答應(yīng)
cmd = logging.StreamHandler()
cmd.setFormatter(format_str)
cmd.setLevel(level)
log.addHandler(cmd)

運(yùn)行結(jié)果:


名字好像可以了,但是日志好像沒有起到自動(dòng)刪除的目的啊,而且也沒在之前的log文件夾了。

來看看源碼:

def getFilesToDelete(self):
    """
    Determine the files to delete when rolling over.

    More specific than the earlier method, which just used glob.glob().
    """
    dirName, baseName = os.path.split(self.baseFilename)
    fileNames = os.listdir(dirName)
    result = []
    prefix = baseName + "."
    plen = len(prefix)
    for fileName in fileNames:
      if fileName[:plen] == prefix:
        suffix = fileName[plen:]
        if self.extMatch.match(suffix):
          result.append(os.path.join(dirName, fileName))
    if len(result) < self.backupCount:
      result = []
    else:
      result.sort()
      result = result[:len(result) - self.backupCount]
    return result

這是它的刪除邏輯,關(guān)鍵是通過 . 前面的字段判斷是否重復(fù),當(dāng)有特定的重復(fù)數(shù)后開始刪除。

所以問題來了,要么自己去重寫源碼,要么就只能用 default.日期.log 這種格式了。

附上平時(shí)使用的日志代碼

import logging
import os
from logging import handlers
def _logging(**kwargs):
  level = kwargs.pop('level', None)
  filename = kwargs.pop('filename', None)
  datefmt = kwargs.pop('datefmt', None)
  format = kwargs.pop('format', None)
  if level is None:
    level = logging.DEBUG
  if filename is None:
    filename = 'default.log'
  if datefmt is None:
    datefmt = '%Y-%m-%d %H:%M:%S'
  if format is None:
    format = '%(asctime)s [%(module)s] %(levelname)s [%(lineno)d] %(message)s'
  log = logging.getLogger(filename)
  format_str = logging.Formatter(format, datefmt)
  def namer(filename):
    return filename.split('default.')[1]
  # cmd = logging.StreamHandler()
  # cmd.setFormatter(format_str)
  # cmd.setLevel(level)
  # log.addHandler(cmd)
  os.makedirs("./debug/logs", exist_ok=True)
  th_debug = handlers.TimedRotatingFileHandler(filename="./debug/" + filename, when='D', backupCount=3,
                         encoding='utf-8')
  # th_debug.namer = namer
  th_debug.suffix = "%Y-%m-%d.log"
  th_debug.setFormatter(format_str)
  th_debug.setLevel(logging.DEBUG)
  log.addHandler(th_debug)
  th = handlers.TimedRotatingFileHandler(filename=filename, when='D', backupCount=3, encoding='utf-8')
  # th.namer = namer
  th.suffix = "%Y-%m-%d.log"
  th.setFormatter(format_str)
  th.setLevel(logging.INFO)
  log.addHandler(th)
  log.setLevel(level)
  return log
os.makedirs('./logs', exist_ok=True)
logger = _logging(filename='./logs/default')

總結(jié)

以上所述是小編給大家介紹的python通過TimedRotatingFileHandler按時(shí)間切割日志,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

相關(guān)文章

  • 詳解python實(shí)現(xiàn)數(shù)據(jù)歸一化處理的方式:(0,1)標(biāo)準(zhǔn)化

    詳解python實(shí)現(xiàn)數(shù)據(jù)歸一化處理的方式:(0,1)標(biāo)準(zhǔn)化

    這篇文章主要介紹了詳解python實(shí)現(xiàn)數(shù)據(jù)歸一化處理的方式:(0,1)標(biāo)準(zhǔn)化,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • python對(duì)指定字符串逆序的6種方法(小結(jié))

    python對(duì)指定字符串逆序的6種方法(小結(jié))

    這篇文章主要介紹了python對(duì)指定字符串逆序的6種方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • 手把手教你python實(shí)現(xiàn)SVM算法

    手把手教你python實(shí)現(xiàn)SVM算法

    這篇文章主要為大家詳細(xì)介紹了手把手教你python實(shí)現(xiàn)SVM算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • 一篇文章教你用Python繪畫一個(gè)太陽系

    一篇文章教你用Python繪畫一個(gè)太陽系

    這篇文章主要給大家介紹了關(guān)于如何利用Python繪畫一個(gè)太陽系,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-10-10
  • python利用線程生成不同尺寸的縮略圖實(shí)例詳解

    python利用線程生成不同尺寸的縮略圖實(shí)例詳解

    這篇文章主要介紹了python利用線程生成不同尺寸的縮略圖,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • python3 實(shí)現(xiàn)對(duì)圖片進(jìn)行局部切割的方法

    python3 實(shí)現(xiàn)對(duì)圖片進(jìn)行局部切割的方法

    今天小編就為大家分享一篇python3 實(shí)現(xiàn)對(duì)圖片進(jìn)行局部切割的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • python?Helium自動(dòng)化庫的功能特性探索

    python?Helium自動(dòng)化庫的功能特性探索

    這篇文章主要為大家介紹了python?Helium自動(dòng)化庫的功能特性探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-02-02
  • Python datetime 格式化 明天,昨天實(shí)例

    Python datetime 格式化 明天,昨天實(shí)例

    這篇文章主要介紹了Python datetime 格式化 明天,昨天實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • Python實(shí)現(xiàn)FM算法解析

    Python實(shí)現(xiàn)FM算法解析

    這篇文章主要介紹了Python實(shí)現(xiàn)FM算法解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • Python標(biāo)準(zhǔn)庫time使用方式詳解

    Python標(biāo)準(zhǔn)庫time使用方式詳解

    這篇文章主要介紹了Python標(biāo)準(zhǔn)庫time使用方式詳解,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下
    2022-07-07

最新評(píng)論