Rumah >pembangunan bahagian belakang >Tutorial Python >10 Petua untuk Menguasai Modul Pengelogan Python
Selain tahap DEBUG, INFO, AMARAN, RALAT dan KRITIKAL lalai, anda boleh membuat tahap tersuai. Ini berguna untuk membezakan peristiwa dengan keparahan yang berbeza-beza.
import logging # 创建自定义日志级别 CUSTOM_LEVEL = logging.INFO + 5 logging.addLevelName(CUSTOM_LEVEL, "CUSTOM") # 创建一个 Logger 并设置自定义日志级别 logger = logging.getLogger("my_logger") logger.setLevel(CUSTOM_LEVEL)
Pengendali bertanggungjawab untuk menghantar acara log ke destinasi tertentu, seperti fail atau konsol. Anda boleh menyesuaikan pemproses untuk memenuhi keperluan khusus anda.
import logging # 创建一个 FileHandler 并设置日志文件名 file_handler = logging.FileHandler("my_log.txt") # 创建一个 StreamHandler 并输出到控制台 stream_handler = logging.StreamHandler() # 将处理器添加到 Logger logger = logging.getLogger("my_logger") logger.addHandler(file_handler) logger.addHandler(stream_handler)
Penapis membolehkan anda menapis peristiwa log berdasarkan kriteria tertentu. Ini berguna untuk mengelog peristiwa yang menarik sahaja.
import logging # 创建一个过滤器以过滤 INFO 级别以上的事件 info_filter = logging.Filter() info_filter.filter = lambda record: record.levelno >= logging.INFO # 将过滤器添加到 Logger logger = logging.getLogger("my_logger") logger.addFilter(info_filter)
Anda boleh menyesuaikan format acara log untuk memberikan maklumat yang anda perlukan.
import logging # 创建一个 FORMatter 并设置格式字符串 formatter = logging.Formatter("%(asctime)s - %(levelname)s - %(message)s") # 将 Formatter 添加到处理器 handler = logging.StreamHandler() handler.setFormatter(formatter) # 将处理器添加到 Logger logger = logging.getLogger("my_logger") logger.addHandler(handler)
Pemproses konteks membolehkan anda menambah maklumat tambahan semasa mengelog. Ini berguna untuk menjejak konteks dalam permintaan atau transaksi.
import logging from contextlib import contextmanager # 创建一个上下文处理器以添加请求 ID @contextmanager def request_id_context(request_id): previous_request_id = logging.currentframe().f_locals.get("request_id") try: logging.currentframe().f_locals["request_id"] = request_id yield finally: logging.currentframe().f_locals["request_id"] = previous_request_id # 使用上下文处理器 logger = logging.getLogger("my_logger") with request_id_context("1234"): logger.info("Received request")
Anda boleh mengkonfigurasi modul Pengelogan dengan mudah menggunakan kamus.
import logging # 配置字典 logging_config = { "version": 1, "formatters": { "default": { "format": "%(asctime)s - %(levelname)s - %(message)s" } }, "handlers": { "file": { "class": "logging.FileHandler", "filename": "my_log.txt", "formatter": "default", }, "console": { "class": "logging.StreamHandler", "formatter": "default", } }, "loggers": { "my_logger": { "handlers": ["file", "console"], "level": "INFO", } } } # 从字典配置 Logging logging.config.dictConfig(logging_config)
Modul pengelogan boleh disepadukan dengan pakej pihak ketiga seperti Sentry atau Rollbar. Ini membolehkan anda menghantar peristiwa log dengan mudah ke perkhidmatan jauh.
import logging import sentry_sdk # 初始化 Sentry 并与 Logging 集成 sentry_sdk.init() logging.basicConfig(level=logging.INFO, handlers=[sentry_sdk.handler.SentryHandler()])
Modul pengelogan menyokong aplikasi berbilang benang . Ia menggunakan storan setempat benang untuk memastikan setiap benang mempunyai pemproses log bebasnya sendiri.
import logging import threading # 创建线程安全的 Logger logger = logging.getLogger("my_logger") # 创建一个线程并向 Logger 记录 def thread_function(): logger.info("Executing in a separate thread") # 启动线程 thread = threading.Thread(target=thread_function) thread.start()
Modul pengelogan boleh merekodkan pengecualian yang berlaku secara automatik.
import logging # 创建一个 Logger logger = logging.getLogger("my_logger") # 记录一个异常 try: raise Exception("An error occurred") except Exception as e: logger.exception(e)
python 3.8 memperkenalkan sokongan untuk pembalakan lanjutan. Ini membolehkan anda mencipta fungsi dan pengendali pengelogan tersuai.
import logging # 创建一个自定义日志记录函数 def my_log_function(logger, level, msg, *args, **kwargs): # 您的自定义日志记录逻辑 # 添加自定义日志记录函数到 Logger logger = logging.getLogger("my_logger") logger.addHandler(logging.NullHandler()) logger.addFilter(logging.Filter()) logger.log = my_log_function
Atas ialah kandungan terperinci 10 Petua untuk Menguasai Modul Pengelogan Python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!