首页 > 滚动

Python 打印彩色日志

2023-01-02 16:36:21

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

断航25年后小清河重新扬帆起航 博兴港以下段今日试航|环球视讯

2022-12-30

每日聚焦:恭喜,全网一姐官宣恋情!街头热吻遭群嘲:“你男友真恶心?”

2022-12-30

知名老戏骨“藏妻”28年,突然高调秀恩爱,妻子首度曝光:难怪他要“拒绝”巩俐!

2022-12-30

重点聚焦!理想L9、L8完成产能爬坡 理想汽车(02015)12月总交付量将突破20000台

2022-12-30

大象转身:科技照进梦想 房企奔流向前 世界今头条

2022-12-30

厦门信达: 厦门信达股份有限公司独立董事意见书_全球即时看

2022-12-29

NBA战报丨激烈冲突3人被驱逐!活塞121-101大胜魔术

2022-12-29

世界热点!数实融合典范!中联重科荣登新型实体企业百强榜

2022-12-29

康华生物12月28日获深股通增持3.27万股

2022-12-29

中国交建最新公告:拟分拆子公司公规院、一公院、二公院重组上市

2022-12-29

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

2022-12-29

22华夏银行CD275今日发布发行公告 全球实时

2022-12-28

全球微头条丨冬笋怎么保存可以放时间长 冬笋如何保存可以放时间长

2022-12-28

全球债券继续下跌 促使日本央行进一步购买债券

2022-12-28

康为世纪(688426)12月27日主力资金净买入41.57万元-环球观天下

2022-12-28

世界热议:山南市乌海县交通违章在网上办理怎么办的?

2022-12-27