登录
首页 >  Golang >  Go问答

logrus 的输出格式多样化

来源:stackoverflow

时间:2024-02-09 15:14:44 354浏览 收藏

哈喽!大家好,很高兴又见面了,我是golang学习网的一名作者,今天由我给大家带来一篇《logrus 的输出格式多样化》,本文主要会讲到等等知识点,希望大家一起学习进步,也欢迎大家关注、点赞、收藏、转发! 下面就一起来看看吧!

问题内容

我的程序以基本方式使用 logrus ,无需任何配置:

   logrus.Info("...")

但是在不同的地方,它以不同的格式输出,有些地方比如:

INFO[0016] pushed

还有一些地方,例如:

time="2023-11-30T05:26:39Z" level=info msg=pushed

不知道背后有什么玄机?


正确答案


让我自我回答一下这个问题。我周末查看了 logrus 代码,发现了其中的棘手之处。

logrus有一个机制来检测当前终端是否有颜色,如果有的话,会以 INFO[0000] Pushed 的格式输出,否则以 time="2023-11-30T05:26:39Z" level= 的格式输出信息 msg=pushed

因此,如果您想始终以第一种格式(较短)输出,那么您只需设置强制颜色:

    logrus.SetFormatter(&logrus.TextFormatter{
        ForceColors: true,
    })

如果您想要第二种格式,则只需强制禁用颜色:

    logrus.SetFormatter(&logrus.TextFormatter{
        DisableColors: true,
    })

您还可以配置时间格式。

今天关于《logrus 的输出格式多样化》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>