python 如何优雅定义自己的log类
时间: 2023-07-10 12:36:36 浏览: 59
要优雅地定义一个自己的log类,你可以使用 Python 自带的 logging 模块。下面是一个简单的示例:
```python
import logging
class MyLogger:
def __init__(self, name):
self.logger = logging.getLogger(name)
self.logger.setLevel(logging.INFO)
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
console_handler = logging.StreamHandler()
console_handler.setFormatter(formatter)
self.logger.addHandler(console_handler)
def info(self, message):
self.logger.info(message)
def warning(self, message):
self.logger.warning(message)
def error(self, message):
self.logger.error(message)
def critical(self, message):
self.logger.critical(message)
```
在这个示例中,我们定义了一个 MyLogger 类,它包装了 Python 的 logging 模块,并提供了 info、warning、error 和 critical 四个方法,分别对应不同的日志级别。你可以通过调用这些方法来记录日志信息。注意,由于 Python 的 logging 模块是线程安全的,因此你可以在多个线程中使用 MyLogger 类的实例。