python 使用裝飾器並記錄log


1.首先定義一個log文件

# -*- coding: utf-8 -*-
import os
import time
import logging
import sys
log_dir1=os.path.join(os.path.dirname(os.path.dirname(__file__)),"logs")
today = time.strftime('%Y%m%d', time.localtime(time.time()))
full_path=os.path.join(log_dir1,today)
if not os.path.exists(full_path):
    os.makedirs(full_path)
log_path=os.path.join(full_path,"facebook.log")
def get_logger():
     # 獲取logger實例,如果參數為空則返回root logger
     logger = logging.getLogger("facebook")
     if not logger.handlers:
            # 指定logger輸出格式
            formatter = logging.Formatter('%(asctime)s %(levelname)-8s: %(message)s')

            # 文件日志
            file_handler = logging.FileHandler(log_path,encoding="utf8")
            file_handler.setFormatter(formatter)  # 可以通過setFormatter指定輸出格式

            # 控制台日志
            console_handler = logging.StreamHandler(sys.stdout)
            console_handler.formatter = formatter  # 也可以直接給formatter賦值

            # 為logger添加的日志處理器
            logger.addHandler(file_handler)
            logger.addHandler(console_handler)

            # 指定日志的最低輸出級別,默認為WARN級別
            logger.setLevel(logging.INFO)
     #  添加下面一句,在記錄日志之后移除句柄
     return  logger

2.然后定義一個裝飾器文件

在這里引用wraps,一個裝飾器的裝飾器,目的為了保持引用進來的函數名字不發生變化

#!/usr/bin/env python  
# encoding: utf-8
from functools import wraps
from logger.log import get_logger
import traceback
def decoratore(func):
    @wraps(func)
    def log(*args,**kwargs):
        try:
            print("當前運行方法",func.__name__)
            return func(*args,**kwargs)
        except Exception as e:
            get_logger().error(f"{func.__name__} is error,here are details:{traceback.format_exc()}")
    return log

  

3.在使用的時候直接在函數上面引用即可

@decorator
def start():
   print("666")

  

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM