Python 打印彩色日志

来源: 时间:2023-01-02 22:48:48

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

最后的话

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

上一篇:

下一篇:

X 关闭

Python 打印彩色日志

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

2023-01-02

环球热头条丨福建省厦门市湖里区交通违章处理要花多长的时间

夏时制:上午8:00-12:00,下午15:00-18:00;非夏时制:上午8:00-12:00;下午14:30-17:30。交通事故责任认定方法:1、当事人有违章行为

2023-01-02

豌豆可以放冰箱吗 豌豆能不能放冰箱

1、豌豆能放冰箱。把豌豆皮剥开,将豌豆(千万不要用水清洗,剥出后直接保存)放进袋子里,密封好以后,平铺整齐(尽量使每粒豆子都很舒服的平

2023-01-01

世界热点!《YOLOv5全面解析教程》​十三,downloads.py 详细解析

前言❝代码仓库地址:https: github com Oneflow-Inc one-yolov5欢迎starone-yolov5项目获取最新的动态。如

2023-01-01

【世界热闻】华宸未来稳健添盈债券A基金经理变动:增聘王斌为基金经理

华宸未来稳健添盈债券A基金经理变动:增聘王斌为基金经理

2022-12-31

【世界新要闻】盐津铺子上榜湖南民营企业百强第68位

12月30日,湖南省人民政府举行2022三湘民营企业百强榜新闻发布会,发布了2022年“三湘民营企业百强榜”,印发了《2022年三湘民营企业百强调研

2022-12-30

内蒙古:因地制宜解码“双碳”,各地有千秋

中新网呼和浩特12月30日电(奥蓝)随着《内蒙古自治区碳达峰实施方案》《建设我国北方重要生态安全屏障实施方案》等方案在内蒙古的发布与实施,

2022-12-30

天津滨海机场元旦假期预计运输旅客6万人次

(王君妍刘承承)元旦小长假即将来临,选择外出旅游的旅客逐步增加。2023年春运即将到来,天津滨海机场仍将全力推动国内外航线航班的新开加密,

2022-12-30

“阳康”后如何接种疫苗?武汉疾控专家权威回应|焦点播报

“阳康”后如何接种疫苗?武汉疾控专家权威回应

2022-12-30

化学制品板块12月29日涨0.17%,瑞丰新材领涨,主力资金净流出1.85亿元

12月29日化学制品板块较上一交易日上涨0 17%,瑞丰新材领涨。当日上证指数报收于3073 7,下跌0 44%。从资金流向上来看,当日化学制品板块主力

2022-12-30

Copyright ©  2015-2022 科技头条网版权所有  备案号:沪ICP备2022005074号-20   联系邮箱:58 55 97 3@qq.com