实时

您的位置:首页>产品 >

Python 打印彩色日志

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

2023-01-01 08:10:01

俯瞰成自宜铁路轨道铺设现场。成兰公司供图人民网成都12月31日电(郭莹)铺轨列车缓缓向前,500米长钢轨在其牵引下稳稳落在结构基底上。今日11

2022-12-31 15:52:48

2021年12月,最高检印发《人民检察院巡回检察工作规定》,进一步明确和规范了监狱、看守所巡回检察工作内容、方法和程序。

2022-12-30 21:47:47

今天大盘震荡上扬,尾盘以阳线报收,与我们之前的预期一致。收官行情是一根阳线,预示明年行情应该不错。当然从年线来看,依旧出现了下跌的状

2022-12-30 18:34:24

2022年即将收官,但债基赎回余波仍未停歇。12月30日华富基金发布公告称,华富恒利债券基金A份额于12月29日发生大额赎回。券商中国记者发现,除

2022-12-30 15:49:24

天士力(600535)12月30日在投资者关系平台上答复了投资者关心的问题。

2022-12-30 09:58:32

◎剀弟展览:胡尹萍个展:胡小芳和乔小幻展期:2022 9 3-12 25地点:明当代美术馆回顾上海下半年的艺术家个展,其

2022-12-30 04:56:23

汪文斌表示,中方始终认为,各国防疫措施应当科学适度,对各国公民一视同仁,不应影响正常的人员交往和交流合作。

2022-12-29 19:40:28

新集能源:新集能源关于持股5%以上股东进行约定购回式证券交易到期购回暨持股变动超过1%的提示性公告

2022-12-29 17:50:19

胜宏科技(300476)12月29日在投资者关系平台上答复了投资者关心的问题。投资者:请问目前国内疫情影响公司正常生产了吗?公司目前的嫁动率是多

2022-12-29 16:05:04

浙富控股12月29日公告,公司通过全资子公司西藏源合参股的星空华文获得香港联交所批准并于12月29日在香港联交所主板上市及买卖,股份代号为:0

2022-12-29 13:39:52

广东塔牌集团股份有限公司                总经理工作细则        广东塔牌集团股份有限公司           

2022-12-29 11:59:36

日前,新疆塔县17岁的塔吉克族女孩阿巴,一大早来到塔县人民医院接待室,将一束鲜花送到武警特色医学中心消化内科主治医师张兴光手中。张兴光

2022-12-29 09:53:46

北京商报讯(记者刘宇阳郝彦)12月28日,天风证券发布公告表示,12月28日,天风证券收到中国证监会批复,核准宏泰集团成为公司控股股东;对联发

2022-12-28 17:25:00

网贷逾期一般会上征信,有些借贷机构在用户逾期后一天后就会上报给征信机构,而有些借贷机构则是会在几天后上报给征信机构,因为有些借贷机构可

2022-12-28 14:57:14

1、建议用三层包装(铝袋、食品级塑料袋、五层厚度的瓦楞纸箱)加以密封,更能保证茶叶免受影响。比如地下室、厨房、阳台房、冰箱等位置,不适

2022-12-28 10:48:42

当地时间12月26日,维多利亚又来秀恩爱啦,她更新了个人INS状态,晒出一张坐在丈夫贝克汉姆腿上的甜蜜合影,值得一提的是,贝嫂还身穿一件印有

2022-12-28 07:09:59

证券代码:002726           证券简称:龙大美食          公告编号:2022-117债券代码:128119           债券简称

2022-12-27 19:13:52

南方财经12月27日电,中国铁建官微发布消息称,日前,中国铁建昆仑投资集团牵头系统内外多家单位(中铁十一局、中国铁建大桥局、中铁十六局、

2022-12-27 15:26:16

点蓝色字关注“机器学习算法工程师”设为星标,干货直达!​PyTorch2 0引入了**torch compile()**来加速模型,这篇文章我们将介绍如何使用

2022-12-27 10:27:10