如何查看彩色日志文件?
How to view colored logs files?
我正在自定义 logger
模块以添加一些颜色。假设我也将流定向到一个文件。以后如何读取该文件?比如,我应该使用哪个软件来正确阅读它,因为它似乎包含基本文本编辑器不知道如何处理的奇怪符号(与颜色格式相关)。
class CustomFormatter(logging.Formatter):
"""Logging colored formatter, adapted from
grey = '\x1b[38;21m'
blue = '\x1b[38;5;39m'
yellow = '\x1b[38;5;226m'
red = '\x1b[38;5;196m'
bold_red = '\x1b[31;1m'
reset = '\x1b[0m'
def __init__(self, fmt):
super().__init__()
self.fmt = fmt
self.FORMATS = {
logging.DEBUG: self.grey + self.fmt + self.reset,
logging.INFO: self.blue + self.fmt + self.reset,
logging.WARNING: self.yellow + self.fmt + self.reset,
logging.ERROR: self.red + self.fmt + self.reset,
logging.CRITICAL: self.bold_red + self.fmt + self.reset
}
def format(self, record):
log_fmt = self.FORMATS.get(record.levelno)
formatter = logging.Formatter(log_fmt)
return formatter.format(record)
输出:
我觉得你可以写日志了to a binary file and then you can read them from the binary file。
您可以创建一个 python 程序来读取您的二进制文件(在您将日志写入该文件之后)并将内容输出到控制台。
我正在自定义 logger
模块以添加一些颜色。假设我也将流定向到一个文件。以后如何读取该文件?比如,我应该使用哪个软件来正确阅读它,因为它似乎包含基本文本编辑器不知道如何处理的奇怪符号(与颜色格式相关)。
class CustomFormatter(logging.Formatter):
"""Logging colored formatter, adapted from
grey = '\x1b[38;21m'
blue = '\x1b[38;5;39m'
yellow = '\x1b[38;5;226m'
red = '\x1b[38;5;196m'
bold_red = '\x1b[31;1m'
reset = '\x1b[0m'
def __init__(self, fmt):
super().__init__()
self.fmt = fmt
self.FORMATS = {
logging.DEBUG: self.grey + self.fmt + self.reset,
logging.INFO: self.blue + self.fmt + self.reset,
logging.WARNING: self.yellow + self.fmt + self.reset,
logging.ERROR: self.red + self.fmt + self.reset,
logging.CRITICAL: self.bold_red + self.fmt + self.reset
}
def format(self, record):
log_fmt = self.FORMATS.get(record.levelno)
formatter = logging.Formatter(log_fmt)
return formatter.format(record)
输出:
我觉得你可以写日志了to a binary file and then you can read them from the binary file。
您可以创建一个 python 程序来读取您的二进制文件(在您将日志写入该文件之后)并将内容输出到控制台。