python3 logging日志封装实例

作者:伪善者 时间:2022-05-23 08:27:52 

一个完整的程序离不开日志,无论是开发阶段,还是测试阶段,亦或程序运行阶段,都可以通过日志查看程序的运行情况,或是定位问题。

下面是对 python3 的日志库 logging 进行了封装,对于大部分的需求应该是能满足的。(如果有不满足的地方,欢迎在下方留言)

程序结构:


|--logger.py
|
|--singleton.py
|
|--demo.py
|
|--log
|  |
|  2018-10-12.log

logger.py


import os
import sys
import time
import logging
from singleton import Singleton

@Singleton   # 如需打印不同路径的日志(运行日志、审计日志),则不能使用单例模式(注释或删除此行)。此外,还需设定参数name。
class Logger:
 def __init__(self, set_level="INFO",
        name=os.path.split(os.path.splitext(sys.argv[0])[0])[-1],
        log_name=time.strftime("%Y-%m-%d.log", time.localtime()),
        log_path=os.path.join(os.path.dirname(os.path.abspath(__file__)), "log"),
        use_console=True):
   """
   :param set_level: 日志级别["NOTSET"|"DEBUG"|"INFO"|"WARNING"|"ERROR"|"CRITICAL"],默认为INFO
   :param name: 日志中打印的name,默认为运行程序的name
   :param log_name: 日志文件的名字,默认为当前时间(年-月-日.log)
   :param log_path: 日志文件夹的路径,默认为logger.py同级目录中的log文件夹
   :param use_console: 是否在控制台打印,默认为True
   """
   if not set_level:
     set_level = self._exec_type() # 设置set_level为None,自动获取当前运行模式
   self.__logger = logging.getLogger(name)
   self.setLevel(getattr(logging, set_level.upper()) if hasattr(logging, set_level.upper()) else logging.INFO) # 设置日志级别
   if not os.path.exists(log_path): # 创建日志目录
     os.makedirs(log_path)
   formatter = logging.Formatter("%(asctime)s - %(name)s - %(levelname)s - %(message)s")
   handler_list = list()
   handler_list.append(logging.FileHandler(os.path.join(log_path, log_name), encoding="utf-8"))
   if use_console:
     handler_list.append(logging.StreamHandler())
   for handler in handler_list:
     handler.setFormatter(formatter)
     self.addHandler(handler)

def __getattr__(self, item):
   return getattr(self.logger, item)

@property
 def logger(self):
   return self.__logger

@logger.setter
 def logger(self, func):
   self.__logger = func

def _exec_type(self):
   return "DEBUG" if os.environ.get("IPYTHONENABLE") else "INFO"

singleton.py


class Singleton:
 """
 单例装饰器。
 """
 __cls = dict()

def __init__(self, cls):
   self.__key = cls

def __call__(self, *args, **kwargs):
   if self.__key not in self.cls:
     self[self.__key] = self.__key(*args, **kwargs)
   return self[self.__key]

def __setitem__(self, key, value):
   self.cls[key] = value

def __getitem__(self, item):
   return self.cls[item]

@property
 def cls(self):
   return self.__cls

@cls.setter
 def cls(self, cls):
   self.__cls = cls

demo.py


import logger

x = logger.Logger("debug")

x.critical("这是一个 critical 级别的问题!")
x.error("这是一个 error 级别的问题!")
x.warning("这是一个 warning 级别的问题!")
x.info("这是一个 info 级别的问题!")
x.debug("这是一个 debug 级别的问题!")

x.log(50, "这是一个 critical 级别的问题的另一种写法!")
x.log(40, "这是一个 error 级别的问题的另一种写法!")
x.log(30, "这是一个 warning 级别的问题的另一种写法!")
x.log(20, "这是一个 info 级别的问题的另一种写法!")
x.log(10, "这是一个 debug 级别的问题的另一种写法!")

x.log(51, "这是一个 Level 51 级别的问题!")
x.log(11, "这是一个 Level 11 级别的问题!")
x.log(9, "这条日志等级低于 debug,不会被打印")
x.log(0, "这条日志同样不会被打印")

"""
运行结果:
2018-10-12 00:18:06,562 - demo - CRITICAL - 这是一个 critical 级别的问题!
2018-10-12 00:18:06,562 - demo - ERROR - 这是一个 error 级别的问题!
2018-10-12 00:18:06,562 - demo - WARNING - 这是一个 warning 级别的问题!
2018-10-12 00:18:06,562 - demo - INFO - 这是一个 info 级别的问题!
2018-10-12 00:18:06,562 - demo - DEBUG - 这是一个 debug 级别的问题!
2018-10-12 00:18:06,562 - demo - CRITICAL - 这是一个 critical 级别的问题的另一种写法!
2018-10-12 00:18:06,562 - demo - ERROR - 这是一个 error 级别的问题的另一种写法!
2018-10-12 00:18:06,562 - demo - WARNING - 这是一个 warning 级别的问题的另一种写法!
2018-10-12 00:18:06,562 - demo - INFO - 这是一个 info 级别的问题的另一种写法!
2018-10-12 00:18:06,562 - demo - DEBUG - 这是一个 debug 级别的问题的另一种写法!
2018-10-12 00:18:06,562 - demo - Level 51 - 这是一个 Level 51 级别的问题!
2018-10-12 00:18:06,562 - demo - Level 11 - 这是一个 Level 11 级别的问题!
"""
2018-10-12.log

2018-10-12 00:18:06,562 - demo - CRITICAL - 这是一个 critical 级别的问题!
2018-10-12 00:18:06,562 - demo - ERROR - 这是一个 error 级别的问题!
2018-10-12 00:18:06,562 - demo - WARNING - 这是一个 warning 级别的问题!
2018-10-12 00:18:06,562 - demo - INFO - 这是一个 info 级别的问题!
2018-10-12 00:18:06,562 - demo - DEBUG - 这是一个 debug 级别的问题!
2018-10-12 00:18:06,562 - demo - CRITICAL - 这是一个 critical 级别的问题的另一种写法!
2018-10-12 00:18:06,562 - demo - ERROR - 这是一个 error 级别的问题的另一种写法!
2018-10-12 00:18:06,562 - demo - WARNING - 这是一个 warning 级别的问题的另一种写法!
2018-10-12 00:18:06,562 - demo - INFO - 这是一个 info 级别的问题的另一种写法!
2018-10-12 00:18:06,562 - demo - DEBUG - 这是一个 debug 级别的问题的另一种写法!
2018-10-12 00:18:06,562 - demo - Level 51 - 这是一个 Level 51 级别的问题!
2018-10-12 00:18:06,562 - demo - Level 11 - 这是一个 Level 11 级别的问题!

来源:https://blog.csdn.net/qq_42486920/article/details/83020693

标签:python3,logging,日志,封装
0
投稿

猜你喜欢

  • 微信公众平台开发——群发信息

    2023-05-19 16:18:48
  • python3中确保枚举值代码分析

    2023-05-23 17:47:31
  • python开发之Docker入门安装部署教程

    2022-12-08 18:31:28
  • Python Gitlab Api 使用方法

    2021-03-11 16:30:11
  • MySql用DATE_FORMAT截取DateTime字段的日期值

    2024-01-14 02:48:22
  • scrapy数据存储在mysql数据库的两种方式(同步和异步)

    2023-07-10 03:29:43
  • python中的信号通信 blinker的使用小结

    2023-07-31 10:05:10
  • mysql中普通索引和唯一索引的效率对比

    2010-12-08 16:03:00
  • go语言K8S 的 informer机制浅析

    2024-05-13 10:44:51
  • Python 文件操作的详解及实例

    2021-06-05 12:59:12
  • bootstrap-table组合表头的实现方法

    2024-05-11 09:07:53
  • Python实现简单多线程任务队列

    2022-07-29 13:21:43
  • pytorch中的卷积和池化计算方式详解

    2021-03-31 19:26:32
  • 一文读懂navicat for mysql基础知识

    2024-01-23 00:46:25
  • 利用python实现查看溧阳的摄影圈

    2021-09-05 21:33:16
  • python+logging+yaml实现日志分割

    2023-12-18 01:19:08
  • ASP和SQL Server如何构建网页防火墙

    2024-01-16 06:01:06
  • python中的opencv和PIL(pillow)转化操作

    2023-04-01 18:54:46
  • sqlserver 中时间为空的处理小结

    2011-11-03 17:16:17
  • 使用python实现knn算法

    2022-01-26 09:33:45
  • asp之家 网络编程 m.aspxhome.com