如何解决如何将 logrus 的输出存储到某个变量?
这是将输入的值转换为 JSON 格式的代码。它显示了正确的输出,但我想存储该输出并使用 fmt.Printf
package main
import (
log "github.com/sirupsen/logrus"
)
func main() {
log.SetFormatter(&log.JSONFormatter{})
standardFields := log.Fields{
"Number of threads": "1","Odd number": "3",}
log.WithFields(standardFields).Info("Golang")
}
解决方法
当您使用 logrus.New() 创建新记录器时,您可以提供 Out
字段以指向您希望的任何 io.Writer
。以下是该字段的文档:
type Logger struct {
// The logs are `io.Copy`'d to this in a mutex. It's common to set this to a
// file,or leave it default which is `os.Stderr`. You can also set this to
// something more adventurous,such as logging to Kafka.
Out io.Writer
...
...
例如,您可以创建一个新的 bytes.Buffer 并将其设置为 Out
字段。这类似于“记录到变量”。
同样,您可以使用 SetOutput 函数设置默认记录器的输出。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。