Python 打印彩色日志 环球短讯

  2023-01-02 16:34:19

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

焦点播报:枸杞的保质期有多久怎么判断是否发霉?

2023-01-02

半圆沙发的好处和坏处?

2023-01-01

天天要闻:平安小橙花网贷逾期会影响征信吗

2022-12-31

天天热资讯!推动发展智慧农业 中联重科君山智慧农场示范园开工

2022-12-30

环球观点:43岁林志玲大胆着装T台秀让人惊艳 但是袜子才是最大亮点

2022-12-30

艳压孙俪、嘲讽海清,这“第一绝色”回归,内娱终于有救了? 焦点滚动

2022-12-30

《穿靴子的猫2》不卖萌,也能过好这一生

2022-12-30

【全球热闻】大成恒生科技ETF(QDII)净值下跌2.24% 请保持关注

2022-12-30

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

2022-12-29

【龙虎榜】台华新材12月29日成交明细 环球热头条

2022-12-29

我所写下的,从零开始的女性主义 全球热消息

2022-12-29

皖能电力12月28日获深股通增持333.43万股 天天速递

2022-12-29

步长制药(603858.SH)拟放弃控股子公司邛崃天银部分股权的优先受让权-世界聚看点

2022-12-29

做零食批发!你可以这样搞 资讯

2022-12-29

今日看点:双成药业:注射用紫杉醇(白蛋白结合型)ANDA发起专利挑战

2022-12-28

排骨肉怎么冷冻保存时间长 排骨肉如何冷冻保存时间长|微头条

2022-12-28

我国最大超深油田富满油田年产油气突破300万吨 天天热议

2022-12-28

汉马科技(600375)12月27日主力资金净买入108.35万元

2022-12-28

关注:永安林业: 2022年度非公开发行A股股票募集资金使用可行性分析报告(修订稿)

2022-12-27

痞幼携男友与网红聚会!对方被曝49岁身家百亿,曾邀黄圣依做代言-聚看点

2022-12-27

青云科技护航清华天津电子院产学研创新

2022-12-27

【手慢无】大屏幕升级6大功能 米家智能温湿度计3新品价49元 环球新资讯

2022-12-27

[快讯]百邦科技:关于实际控制人的一致行动人、董事、高级管理人员减持股份预披露

2022-12-26

C919大飞机开始验证飞行:别再拿国产化率说事了!

2022-12-26

精彩图集