2021-01-22 Python TimedRotatingFileHandlerは、サフィックスを変更した後、ファイルを自動的に削除できません

Python TimedRotatingFileHandlerは、サフィックスを変更した後、ファイルを自動的に削除できません

TimedRotatingFileHandler万法

“S”: Seconds
“M”: Minutes
“H”: Hours
“D”: Days
“W”: Week day (0=Monday)
“midnight”: Roll over at midnight

1のログを設計し、3つ以上を削除します

	log = logging.getLogger()
	log.setLevel(logging.ERROR)  # 日志等级为ERROR
	
	fh = logging.handlers.TimedRotatingFileHandler("log", when='S', interval=1, backupCount=3)
	fh.suffix = "%Y-%m-%d_%H-%M-%S.log"
	formatter = logging.Formatter('[%(asctime)s] - %(filename)s [Line:%(lineno)d] - [%(levelname)s]-[thread:%(thread)s]-[process:%(process)s] - %(message)s') 
	fh.setFormatter(formatter)
	log.addHandler(fh)
	i = 0
	while i < 100000000:
	    sleep(0.1)
	    log.error("记录" + str(i))
	    i = i + 1

結果は削除されません

ここに写真の説明を挿入

TimedRotatingFileHandlerのソースコードを表示する

def __init__(self, filename, when='h', interval=1, backupCount=0, encoding=None, delay=False, utc=False):
        BaseRotatingHandler.__init__(self, filename, 'a', encoding, delay)
        self.when = when.upper()
        self.backupCount = backupCount
        self.utc = utc      
        if self.when == 'S':
            self.interval = 1 # one second
            self.suffix = "%Y-%m-%d_%H-%M-%S"
            self.extMatch = r"^\d{4}-\d{2}-\d{2}_\d{2}-\d{2}-\d{2}$"
        elif self.when == 'M':
            self.interval = 60 # one minute
            self.suffix = "%Y-%m-%d_%H-%M"
            self.extMatch = r"^\d{4}-\d{2}-\d{2}_\d{2}-\d{2}$"
        elif self.when == 'H':
            self.interval = 60 * 60 # one hour
            self.suffix = "%Y-%m-%d_%H"
            self.extMatch = r"^\d{4}-\d{2}-\d{2}_\d{2}$"
        elif self.when == 'D' or self.when == 'MIDNIGHT':
            self.interval = 60 * 60 * 24 # one day
            self.suffix = "%Y-%m-%d"
            self.extMatch = r"^\d{4}-\d{2}-\d{2}$"
        elif self.when.startswith('W'):
            self.interval = 60 * 60 * 24 * 7 # one week
            if len(self.when) != 2:
                raise ValueError("You must specify a day for weekly rollover from 0 to 6 (0 is Monday): %s" % self.when)
            if self.when[1] < '0' or self.when[1] > '6':
                raise ValueError("Invalid day specified for weekly rollover: %s" % self.when)
            self.dayOfWeek = int(self.when[1])
            self.suffix = "%Y-%m-%d"
            self.extMatch = r"^\d{4}-\d{2}-\d{2}$"
        else:
            raise ValueError("Invalid rollover interval specified: %s" % self.when)

        self.extMatch = re.compile(self.extMatch)
        self.interval = self.interval * interval # multiply by units requested
        if os.path.exists(filename):
            t = os.stat(filename)[ST_MTIME]
        else:
            t = int(time.time())
        self.rolloverAt = self.computeRollover(t)

キーは次の行です

self.suffix = "%Y-%m-%d_%H-%M-%S"
self.extMatch = r"^\d{4}-\d{2}-\d{2}_\d{2}-\d{2}-\d{2}$"
······
······
self.extMatch = re.compile(self.extMatch)

whenタイプがデフォルトで設定された後、サフィックスが固定され、一致する規則性もソースコードに書き込まれるため、サフィックスを変更する場合は、規則性を一緒に変更する必要があります

最終的なコードは次のとおりです

log = logging.getLogger()
log.setLevel(logging.ERROR)  # 日志等级为ERROR

fh = logging.handlers.TimedRotatingFileHandler("log", when='S', interval=1, backupCount=3)
fh.suffix = "%Y-%m-%d_%H-%M-%S.log"
fh.extMatch = r"^\d{4}-\d{2}-\d{2}_\d{2}-\d{2}-\d{2}.log$"
fh.extMatch = re.compile(fh.extMatch)
formatter = logging.Formatter('[%(asctime)s] - %(filename)s [Line:%(lineno)d] - [%(levelname)s]-[thread:%(thread)s]-[process:%(process)s] - %(message)s') 
fh.setFormatter(formatter)
log.addHandler(fh)
i = 0
while i < 100000000:
    sleep(0.1)
    log.error("记录" + str(i))
    i = i + 1

 

 

 

おすすめ

転載: blog.csdn.net/qingfengxd1/article/details/112982026