Python 打印彩色日志

时间:2023-01-01 23:37:47 来源:

我相信每一个开发者都有打印日志的习惯,好看的日志可以加快调试的速度,可以更好的了解程序中发生的事情。本文分享一个技巧,可以让 Python 在控制台输出彩色的日志。

安装 coloredlogs

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")

最后的话

本文分享了一种输出彩色日志的方法,感觉不错的话,请分享给身边的程序员们,祝编码愉快。

标签: 正常使用

精彩推送

北京支持养老护理行业发展 开展技能大赛促人才培养

  中新网北京9月22日电 (记者 杜燕)今天,记者从北京市民政局了解到,北京将继续大力支持养老护理行...

来源:2021.09.23

2021第七届慈孝文化节启幕 以“慈孝”为窗讲中华故事

  中新网杭州9月22日电 (记者 方堃)9月22日,2021第七届慈孝文化节在浙江杭州启幕。本届慈孝文化节...

来源:2021.09.23

厦门核酸检测提速 近9000名医护人员投入

  (抗击新冠肺炎)厦门核酸检测提速 近9000名医护人员投入  中新网厦门9月22日电 (记者 杨伏山)同...

来源:2021.09.23

邓亚萍、侯京健、郑培钦受聘“2021慈孝文化大使”

  中新网杭州9月22日电(记者 胡丰盛)22日下午,在浙江杭州举行的“2021第七届慈孝文化节”开幕式上,...

来源:2021.09.23

2021北京国际设计周开幕 北斗卫星导航系统获经典设计奖

  中新网北京9月22日电 (记者 陈杭)22日,2021北京国际设计周开幕活动暨北京2022年冬奥会和冬残奥会...

来源:2021.09.23

《内蒙古自治区草畜平衡和禁牧休牧条例》10月1日起实施 明确禁牧区划定范围等

  中新网呼和浩特9月22日电 (记者 李爱平)内蒙古自治区人大常委会法工委副主任尹国惠22日在此间召开...

来源:2021.09.23

京津冀印刷业协同发展北京创新示范园区开园

  中新网北京9月22日电 (记者 杜燕)今天,记者从北京印刷学院了解到,京津冀印刷业协同发展北京创新...

来源:2021.09.23

湖北红安:黄牛跌入深井 消防员灌水巧救牛

  中新网黄冈9月22日电 (刘成 徐普查 汪洁成)湖北省黄冈市红安县杏花乡李家冲村一头黄牛21日不慎掉...

来源:2021.09.23

中秋假期辽宁实现旅游总收入49.7亿元 赏月夜游成新时尚

  中新网沈阳9月22日电 (韩宏)辽宁省文化和旅游厅22日发布消息称,3天假期,辽宁累计接待游客620 1...

来源:2021.09.23

新闻快讯

X 关闭

X 关闭

新闻快讯