本文介绍了Python 根据日志级别打印不同颜色的日志的方法示例,分享给大家,具体如下:
# -*-coding:UTF-8-*- import logging import os import time class logger(object): """ 终端打印不同颜色的日志,在pycharm中如果强行规定了日志的颜色, 这个方法不会起作用, 但是 对于终端,这个方法是可以打印不同颜色的日志的。 """ #在这里定义StreamHandler,可以实现单例, 所有的logger()共用一个StreamHandler ch = logging.StreamHandler() def __init__(self): self.logger = logging.getLogger() if not self.logger.handlers: #如果self.logger没有handler, 就执行以下代码添加handler self.logger.setLevel(logging.DEBUG) from serviceProgram.utils.FileUtil import FileUtil rootPath = FileUtil.getProgrameRootPath() self.log_path = rootPath + '/logs' if not os.path.exists(self.log_path): os.makedirs(self.log_path) # 创建一个handler,用于写入日志文件 fh = logging.FileHandler(self.log_path + '/runlog' + time.strftime("%Y%m%d", time.localtime()) + '.log', encoding='utf-8') fh.setLevel(logging.INFO) # 定义handler的输出格式 formatter = logging.Formatter('[%(asctime)s] - [%(levelname)s] - %(message)s') fh.setFormatter(formatter) # 给logger添加handler self.logger.addHandler(fh) def debug(self, message): self.fontColor('\033[0;32m%s\033[0m') self.logger.debug(message) def info(self, message): self.fontColor('\033[0;34m%s\033[0m') self.logger.info(message) def warning(self, message): self.fontColor('\033[0;37m%s\033[0m') self.logger.warning(message) def error(self, message): self.fontColor('\033[0;31m%s\033[0m') self.logger.error(message) def critical(self, message): self.fontColor('\033[0;35m%s\033[0m') self.logger.critical(message) def fontColor(self, color): #不同的日志输出不同的颜色 formatter = logging.Formatter(color % '[%(asctime)s] - [%(levelname)s] - %(message)s') self.ch.setFormatter(formatter) self.logger.addHandler(self.ch) if __name__ == "__main__": logger = logger() logger.info("12345") logger.debug("12345") logger.warning("12345") logger.error("12345")
实现过程:
终端的字符颜色是用转义序列控制的,是文本模式下的系统显示功能,和具体的语言无关。
转义序列是以ESC开头,即用\033来完成(ESC的ASCII码用十进制表示是27,用八进制表示就是033)。
书写格式:
开头部分:\033[显示方式;前景色;背景色m + 结尾部分:\033[0m
注意:开头部分的三个参数:显示方式,前景色,背景色是可选参数,可以只写其中的某一个;另外由于
表示三个参数不同含义的数值都是唯一的没有重复的,所以三个参数的书写先后顺序没有固定要求,系统
都能识别;但是,建议按照默认的格式规范书写。
对于结尾部分,其实也可以省略,但是为了书写规范,建议\033[***开头,\033[0m结尾。
数值表示的参数含义:
常见开头格式:
- \033[0m 默认字体正常显示,不高亮
- \033[32;0m 红色字体正常显示
- \033[1;32;40m 显示方式: 高亮 字体前景色:绿色 背景色:黑色
- \033[0;31;46m 显示方式: 正常 字体前景色:红色 背景色:青色
实例:
(1)print("\033[1;31;40m您输入的帐号或密码错误!\033[0m")
上方代码的输出格式为:字体高亮,红色前景,黄色背景 PS:前景色也就是字体的颜色
(2)print("\033[0;31m%s\033[0m" % "输出红色字符")
#上方代码的输出格式为:字体默认,红色前景
LOG_INFO='INFO' LOG_ERROR='ERROR' LOG_WARNING='WARNING' LOG_NOTIFY='NOTIFY' LOG_DEBUG='DEBUG' LOG_USER='USER' def info_log(value): if log_level > 3: print("\033[0;37;40m%s\033[0m"%value) def error_log(value): if log_level != 0: print("\033[0;31;40m%s\033[0m"%value) def warning_log(value): if log_level > 1: print("\033[0;33;40m%s\033[0m"%value) def debug_log(value): if log_level > 5: print("\033[0;34;40m%s\033[0m"%value) def notify_log(value): if log_level > 2: print("\033[0;36;40m%s\033[0m"%value) def user_log(value): if log_level > 4: print("\033[0;32;40m%s\033[0m"%value) def ZLOG(log_type,value): switcher={ 'INFO':info_log, 'ERROR':error_log, 'WARNING':warning_log, 'DEBUG':debug_log, 'NOTIFY':notify_log, 'USER':user_log } return switcher[log_type](value) test="hello world" ZLOG(LOG_INFO,"output info log %s"%test)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
python,打印颜色日志
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。