焦点关注:Python 打印彩色日志
2023-01-01 23:26:20来源:
我相信每一个开发者都有打印日志的习惯,好看的日志可以加快调试的速度,可以更好的了解程序中发生的事情。本文分享一个技巧,可以让 Python 在控制台输出彩色的日志。
安装 coloredlogspipinstallcoloredlogs使用
首先,和正常打印日志一样,我们创建一个 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
- 韩国高速公路车祸引发火灾致5人死亡
- 天天热讯:寒冬中,这群社区救助顾问为他们送去温暖
- 2023年春季厦门思明区转学怎么咨询?
- 2023苏州乐园跨年活动指南
- 天天通讯!通业科技:融资净买入10.14万元,融资余额2363.22万元(12-29)
- 全球视讯!聚焦高质量发展|助企纾困添活力 江西超800亿元税费“红包”落地见效
- 京唐城际铁路天津段最新进展(更新中)_最新
- 视频 | 走进中国电影博物馆 光影中感受时代风华|讯息
- 当前快看:长沙机场到萍乡的快巴有几趟车呢?
- 全球信息:基因编辑板块12月28日涨1.51%,乐普医疗领涨,主力资金净流出8354.61万元
- 每日资讯:国富创新(00290)拟溢价约8.33%配售最多约2.197亿股 净筹5682万港元
- 【天天速看料】受伤流血的句子精选239句
- 物产环能:员工持股平台拟减持不超6%公司股份
- 12月28日数字货币板块跌幅达2%-速讯
- 世界关注:2022年“品质鲁药”名单出炉,鲁南制药舒尔佳等4款产品上榜
- 离婚后的他有新恋情了?被曝带女友做妇科检查,疑似即将当爸爸
- 天奈科技: 江苏天奈科技股份有限公司2022年度向特定对象发行A股股票募集资金使用的可行性分析报告|世界即时
- 今日热文:GO 1.20 新功能:多重错误包装