dongzhuner6981 2016-11-09 08:03
浏览 8
已采纳

如何将对数时间设置为UTC

I am using Go with logrus, however I found the time field is always formatted in local time. How can I change the time to UTC time for logrus?

Thanks

  • 写回答

2条回答 默认 最新

  • doutou6803 2016-11-09 08:30
    关注

    Time zone setting is not supported directly, but you may use a custom log.Formatter in which you may "switch" to the time zone of your choice, UTC included.

    A simple usage that uses the local time zone (not UTC) may look like this:

    import (
        log "github.com/Sirupsen/logrus"
    )
    
    func main() {
        log.SetFormatter(&log.JSONFormatter{})
        log.Info("Testing")
    }
    

    Output (time is formatted using my +01 local timezone):

    {"level":"info","msg":"Testing","time":"2016-11-09T09:28:02+01:00"}
    

    Now let's create a custom log.Formatter which switches to UTC:

    type UTCFormatter struct {
        log.Formatter
    }
    
    func (u UTCFormatter) Format(e *log.Entry) ([]byte, error) {
        e.Time = e.Time.UTC()
        return u.Formatter.Format(e)
    }
    
    func main() {
        log.SetFormatter(UTCFormatter{&log.JSONFormatter{}})
        log.Info("Testing")
    }
    

    Output (time is formatted in UTC timezone):

    {"level":"info","msg":"Testing","time":"2016-11-09T08:28:09Z"}
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 使用EMD去噪处理RML2016数据集时候的原理
  • ¥15 神经网络预测均方误差很小 但是图像上看着差别太大
  • ¥15 Oracle中如何从clob类型截取特定字符串后面的字符
  • ¥15 想通过pywinauto自动电机应用程序按钮,但是找不到应用程序按钮信息
  • ¥15 如何在炒股软件中,爬到我想看的日k线
  • ¥15 seatunnel 怎么配置Elasticsearch
  • ¥15 PSCAD安装问题 ERROR: Visual Studio 2013, 2015, 2017 or 2019 is not found in the system.
  • ¥15 (标签-MATLAB|关键词-多址)
  • ¥15 关于#MATLAB#的问题,如何解决?(相关搜索:信噪比,系统容量)
  • ¥500 52810做蓝牙接受端