Python 打印彩色日志_世界最资讯
我相信每一个开发者都有打印日志的习惯,好看的日志可以加快调试的速度,可以更好的了解程序中发生的事情。本文分享一个技巧,可以让 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-01-01
-
我的2023新春寄语 | 10位文化名人陪你跨年!
2023-01-01
-
天天资讯:境外媒体关注:中国旅游业回稳向好势头明显
2022-12-31
-
华润三九(000999.SZ):昆药集团28%股份已过户至公司名下 世界实时
2022-12-30
-
佛山个人无犯罪证明网上办理指南(入口+流程)_天天视讯
2022-12-30
-
-
戴德梁行:香港和上海仍是中国商业地产最具吸引力投资目的地|全球讯息
2022-12-30
-
全球今日报丨医保这一年:综合保障能力加强 惠及百姓民生
2022-12-30
-
贵阳观山湖区非急危重症转运专班电话是多少|环球播资讯
2022-12-29
-
我国生态环境建设取得巨大成效
2022-12-29
-
Python 打印彩色日志_世界最资讯
2023-01-01
-
我的2023新春寄语 | 10位文化名人陪你跨年!
2023-01-01
-
天天资讯:境外媒体关注:中国旅游业回稳向好势头明显
2022-12-31
-
华润三九(000999.SZ):昆药集团28%股份已过户至公司名下 世界实时
2022-12-30
-
佛山个人无犯罪证明网上办理指南(入口+流程)_天天视讯
2022-12-30
-
-
戴德梁行:香港和上海仍是中国商业地产最具吸引力投资目的地|全球讯息
2022-12-30
-
全球今日报丨医保这一年:综合保障能力加强 惠及百姓民生
2022-12-30
-
贵阳观山湖区非急危重症转运专班电话是多少|环球播资讯
2022-12-29
-
我国生态环境建设取得巨大成效
2022-12-29
-
全球热门:佛山顺德龙江核酸检测地点最新汇总(持续更新)
2022-12-29
-
世界热议:依米康(300249.SZ):江苏亿金拟将辽宁亿金70%股权转让给江苏贝吉
2022-12-29
-
思源电气(002028.SZ):拟以6.18亿元收购烯晶碳能41.1985%的股权
2022-12-29
-
祝爸爸一路走好的句子(精选371句)
2022-12-28
-
山西省汾西县车辆违章处理费-当前快讯
2022-12-28
-
绿叶制药:LY03010上市申请已获国家药监局受理|世界观焦点
2022-12-28
-
Alex 2022年最后一次水逆对12星座的影响|最新快讯
2022-12-28
-
长征四号圆满完成今年全部发射任务|天天动态
2022-12-28
-
触目惊心!这些贪腐和违规的上市公司高管们-世界新要闻
2022-12-27
-
GO 1.20 新功能:多重错误包装
2022-12-27
-
【问答】小顾有问必答(九)
2022-12-27
-
三旺通信: 第二届董事会第七次会议决议公告
2022-12-26
-
报道:12月26日钱江摩托涨5.91%,华安安信消费混合A基金重仓该股
2022-12-26
-
【世界报资讯】高管年底变动再掀小高潮,年内已有124家公募走马换将
2022-12-26
-
俄媒:中俄加强体育赛事合作 每日速递
2022-12-25
-
44岁秦海璐全家出游!背万元包素颜显浮肿,患巨婴症儿子超惹眼
2022-12-25
-
如何判断是新冠而不是感冒?会合并感染吗?
2022-12-24
-
新鲜当归保存多久有效 新鲜当归保存的时间
2022-12-23
-
澳柯玛正式官宣孙俪为全新品牌形象代言人
2022-12-23
-
世茂股份:12月22日融券卖出金额9.19万元,占当日流出金额的0.49% 世界快讯
2022-12-23