Python 打印彩色日志|世界微动态
2023-01-01 23:33:06来源:
我相信每一个开发者都有打印日志的习惯,好看的日志可以加快调试的速度,可以更好的了解程序中发生的事情。本文分享一个技巧,可以让 Python 在控制台输出彩色的日志。
(资料图)
pipinstallcoloredlogs使用
首先,和正常打印日志一样,我们创建一个 logger
logging.basicConfig()logger=logging.getLogger(name="mylogger")
然后,把 logger 安装到 coloredlogs:
coloredlogs.install(logger=logger)logger.propagate=False
logger.propagate = False确保 coloredlogs 不会将我们的日志事件传递给根 logger,这可以防止我们重复记录每个事件。
我们想为我们的控制台输出添加一些样式,可以在这里定义:
coloredFormatter=coloredlogs.ColoredFormatter(fmt="[%(name)s]%(asctime)s%(funcName)s%(lineno)-3d%(message)s",level_styles=dict(debug=dict(color="white"),info=dict(color="blue"),warning=dict(color="yellow",bright=True),error=dict(color="red",bold=True,bright=True),critical=dict(color="black",bold=True,background="red"),),field_styles=dict(name=dict(color="white"),asctime=dict(color="white"),funcName=dict(color="white"),lineno=dict(color="white"),))
接下来就和正常使用日志一样了,配置一个流处理器,让日志显示在控制台:
ch=logging.StreamHandler(stream=sys.stdout)ch.setFormatter(fmt=coloredFormatter)logger.addHandler(hdlr=ch)logger.setLevel(level=logging.DEBUG)
接下来就可以输入日志信息了:
logger.debug(msg="thisisadebugmessage")logger.info(msg="thisisaninfomessage")logger.warning(msg="thisisawarningmessage")logger.error(msg="thisisanerrormessage")logger.critical(msg="thisisacriticalmessage")
效果图如下:
完整代码如下:
importloggingimportcoloredlogsimportsys##配置loggerlogging.basicConfig()logger=logging.getLogger(name="mylogger")coloredlogs.install(logger=logger)logger.propagate=False##配置颜色coloredFormatter=coloredlogs.ColoredFormatter(fmt="[%(name)s]%(asctime)s%(funcName)s%(lineno)-3d%(message)s",level_styles=dict(debug=dict(color="white"),info=dict(color="blue"),warning=dict(color="yellow",bright=True),error=dict(color="red",bold=True,bright=True),critical=dict(color="black",bold=True,background="red"),),field_styles=dict(name=dict(color="white"),asctime=dict(color="white"),funcName=dict(color="white"),lineno=dict(color="white"),))##配置StreamHandlerch=logging.StreamHandler(stream=sys.stdout)ch.setFormatter(fmt=coloredFormatter)logger.addHandler(hdlr=ch)logger.setLevel(level=logging.DEBUG)##outputlogger.debug(msg="thisisadebugmessage")logger.info(msg="thisisaninfomessage")logger.warning(msg="thisisawarningmessage")logger.error(msg="thisisanerrormessage")logger.critical(msg="thisisacriticalmessage")最后的话
本文分享了一种输出彩色日志的方法,感觉不错的话,请分享给身边的程序员们,祝编码愉快。
相关新闻
- Python 打印彩色日志|世界微动态
- 2022昌江县四级工伤赔偿期限怎么规定
- 天天关注:黄金消费升温 生肖系列黄金饰品受青睐
- 每日热讯!兴瑞科技(002937):选举职工代表监事
- 当前信息:扬州凤凰岛2023淡旺季门票价格
- 环球微速讯:刚刚,出身寒门,曾经的商界大佬,有期徒刑19年!
- IPO | 生物降解塑料产品生产商中宝新材递表港交所主板 观察
- 12月29日基金净值:广发恒享一年持有期混合A最新净值0.9801,跌0.1% 焦点
- 焦点报道:2023杭州春节留杭消费券要交多久社保?
- 全球资讯:民航局:明年1月8日起不再定义入境高风险航班
- 2022苏州银行金融市场总部投资交易部招聘报名时间+报名入口
- 纵横谈|从年度热词中感受行稳致远的力量
- 中达集团控股(00139)附属与中启传媒科技就成立合资企业订立合作框架协议
- 线上毕业答辩朋友圈文案(毕业答辩结束朋友圈文案)
- 2023济南个人所得税继续教育专项附加扣除标准 世界热头条
- 【环球聚看点】万年青:受疫情影响,今年以来没有机构投资者到公司现场调研
- 健康中国|新冠感染后会不会引发心肌炎?专家回应|全球快播
- 煮茶叶蛋的水用老换吗
- 当前快讯:港媒:“这当然是痴人说梦”
- 当前简讯:2022年宁夏重大项目开复工率达100%