>백엔드 개발 >파이썬 튜토리얼 >Python 로그를 구성하는 방법

Python 로그를 구성하는 방법

WBOY
WBOY앞으로
2023-05-24 15:37:151735검색

구성

구성 경향

  • 파일로만 출력

  • 시간별 회전, 기본 7d

  • 로그 형식: 필요한 정보만 기록

import logging
from logging.handlers import TimedRotatingFileHandler
from os import path
def init_log_config(
        filename: str,
        *,
        default_dir="/var/log",
        logformat: str = ("[%(levelname)s %(asctime)s %(process)d_%(threadName)s %(filename)s:%(lineno)s:%(funcName)s] "
                          "%(message)s"),
        loglevel: str = "warn",
        backup_count: int = 7,
        encoding="utf-8",
        delay=True,
):
    """
    :param filename: 文件名
    :param default_dir: 
    :param logformat: 
    :param loglevel: 
    :param backup_count: 
    :param encoding: 
    :param delay: 
    :return: 
    """
    levelint = {
        "debug": logging.DEBUG,
        "info": logging.INFO,
        "warn": logging.WARN,
        "error": logging.ERROR
    }[loglevel]
    if not filename.startswith("/"):
        filename = path.join(default_dir, filename)
    logging.basicConfig(
        format=logformat,
        level=levelint,
        handlers=[
            TimedRotatingFileHandler(
                filename,
                when="d",
                backupCount=backup_count,
                encoding=encoding,
                delay=delay,
            )
        ]
    )

Usage

  • 프로그램이 가장 맨 처음부터 초기화를 시작합니다. (보통 첫 줄에 넣습니다.)

init_log_config("log1.log", loglevel="debug")
import os, sys
  • 비즈니스에서 사용됩니다

logging.info("Start Do something")

위 내용은 Python 로그를 구성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제