天天消息!Python 打印彩色日志

2023-01-01 23:33:01 | 来源:

我相信每一个开发者都有打印日志的习惯,好看的日志可以加快调试的速度,可以更好的了解程序中发生的事情。本文分享一个技巧,可以让 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")

最后的话

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

上一篇 下一篇

相关新闻

天天消息!Python 打印彩色日志

陕西文旅惠民卡使用攻略|新资讯

回暖!湖南机场元旦小长假客流预计突破12万人次 环球热推荐

“三支箭”落地有声信贷资金近5万亿元、超百家房企获授信

郑州园博园开园公告

焦点信息:佛山公积金退休无感提取服务范围是什么?

消失17年后,55岁王祖贤近况曝光,判若两人:一代女神竟变成这样…

陆金贷(小额应急)网贷逾期七天延迟还款征信会怎么样

北京海淀区东升镇新冠疫苗第四针接种点详情 环球热议

国内是否有德尔塔变异株流行?德尔塔与奥密克戎有无共循环或重组?专家回应【科学防疫小贴士】(66) 天天微资讯

天天热文:2022年宁波工行数币红包活动在哪里报名

颐丰食品每10股派现3元共计派发现金红利2137.5万元 速递

【环球快播报】再签融资租赁协议,滨海投资(02886.HK)12月累计新增融资6.7亿元

激励自己学数学的句子(精选548句)

微信号、手机验证码或确认属于公民个人信息|今日热闻

最新新闻

天天消息!Python 打印彩色日志

陕西文旅惠民卡使用攻略|新资讯

回暖!湖南机场元旦小长假客流预计突破12万人次 环球热推荐

“三支箭”落地有声信贷资金近5万亿元、超百家房企获授信

郑州园博园开园公告

焦点信息:佛山公积金退休无感提取服务范围是什么?

消失17年后,55岁王祖贤近况曝光,判若两人:一代女神竟变成这样…

陆金贷(小额应急)网贷逾期七天延迟还款征信会怎么样

北京海淀区东升镇新冠疫苗第四针接种点详情 环球热议

国内是否有德尔塔变异株流行?德尔塔与奥密克戎有无共循环或重组?专家回应【科学防疫小贴士】(66) 天天微资讯

天天热文:2022年宁波工行数币红包活动在哪里报名

颐丰食品每10股派现3元共计派发现金红利2137.5万元 速递

【环球快播报】再签融资租赁协议,滨海投资(02886.HK)12月累计新增融资6.7亿元

激励自己学数学的句子(精选548句)

微信号、手机验证码或确认属于公民个人信息|今日热闻

天天播报:金市健言:黄金1832空!白银24.2空!原油81空!天然气

【世界新视野】康泰医学:目前血氧仪日产量超过十万台/套

过错责任原则是什么-当前聚焦

腌制品煮多久才能吃 煮熟腊肉的时间

GO 1.20 新功能:多重错误包装-天天通讯

天天热讯:猪价全年一波多折,行业重陷亏损 明年猪周期怎么投?

全球即时看!恒太照明(873339):[临时]:职工代表监事离职

美宝《曜言派》带你聆听父子之间的对抗与和解

华泰证券(601688):华泰证券股份有限公司2022年面向专业投资者公开发行公司债券(第九期)(品种一)上市 世界新资讯

世界今日报丨超越ConvNeXt!Transformer 风格的卷积网络视觉基线模型Conv2Former

“冬日暖阳”普照光伏产业

环球时讯:口子窖(603589)12月23日主力资金净买入5967.28万元

今日看点:保险业协会首次发布种植业、养殖业、森林保险承保理赔服务规范

【机构调研记录】新华基金调研天马科技、美亚柏科|全球观速讯

招行信用卡重拳打击违规代理投诉 净化行业生态 维护金融秩序|今日聚焦