Python 打印彩色日志

2023-01-01 23:37:04 来源:

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

天天快消息!臻有钱分期借款逾期七天多久上征信

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

2023-01-01 07:32:34

三伏天不适合做什么?

其实吧三伏天什么都不适合做,做什么都是一身汗,就开个空调抱着手机躺着,再来个西瓜。开个玩笑啊,人...

2022-12-31 15:28:00

C罗乔治娜约会!久违过二人世界,开未婚妻送的豪车,满面红光

北京时间12月30日,葡萄牙巨星C罗被路人拍到,驾驶着未婚妻乔治娜刚刚在圣诞送给他的劳斯莱斯座驾出行,...

2022-12-30 20:19:43

焦点资讯:2023少林寺元旦免票吗

2023少林寺元旦期间免票吗免票。2022年12月31日-2023年1月2日,少林景区,少林寺常住院、塔林、二祖庵、...

2022-12-30 17:26:21

锦和商管(603682)12月30日主力资金净卖出96.42万元

截至2022年12月30日收盘,锦和商管(603682)报收于5 41元,上涨2 27%,换手率1 63%,成交量2 93万手,成交额1570 98万元。

2022-12-30 14:59:20

世界要闻:*ST必康12月30日开盘涨停

以下是*ST必康在北京时间12月30日09:26分盘口异动快照:12月30日9点26分,*ST必康开盘涨停,报6 96元,...

2022-12-30 09:21:46

12月29日基金净值:大成景气精选六个月持有混合A最新净值0.8425,涨0.74% 世界快播

12月29日,大成景气精选六个月持有混合A最新单位净值为0 8425元,累计净值为0 8425元,较前一交易日上...

2022-12-30 01:02:55

佛山健康南海通小程序新冠药物库存查询入口

佛山健康南海通新冠用药库存查询:查询入口:健康南海通微信小程序>>>佛山怎么查看各大药房新冠用药库存...

2022-12-29 19:21:50

中国赴马里维和医疗分队成功救治3名外籍受伤士兵 天天消息

5月29日,中国第9批赴马里维和医疗分队紧急收治3名遭遇爆炸袭击的埃及士兵。经过分队医护人员治疗,3名...

2022-12-29 17:15:00
x 广告
x 广告

Copyright  2015-2022 起点粮油网版权所有  备案号:皖ICP备2022009963号-12   联系邮箱: 39 60 29 14 2@qq.com