drbe16008 2019-05-11 22:51
浏览 44
已采纳

替换* os.Go默认日志文件

I'm trying to write a wrapper for Go's built-in logger. This is to have compatibility.

package main

import (
    "log"
    "os"
)

var(
    mylog *log.Logger
)

func main() {
    mylog = log.New(os.Stdout, "", 0)
    mylog.Printf("test")
}

Instead of using os.Stdout, I want to create one something. Similar to os.Stdout but prints with prefix like below.

package main

import( 
    "log"
    "mylibrary"
)

var(
    mylog *log.Logger
)

func main() {
    mylog = log.New(mylibrary.Prefix, "", 0)
    mylog.Printf("test")
}

Basically, I still want to have *log.Logger while having custom log. Can someone give me a hint how I can make this works?

Currently, I'm using following to do that. But I bet there's a better way.

func NewIoWriter(f func(string)) *io.PipeWriter {
    r, w := io.Pipe()
    go func() {
        scanner := bufio.NewScanner(r)
        for scanner.Scan() {
            f(scanner.Text())
        }
        if err := scanner.Err(); err != nil {
            f(err.Error())
        }
        r.Close()
    }()
    runtime.SetFinalizer(w, (*io.PipeWriter).Close)
    return w
}

What would be the better way to make it work?

Thank you

  • 写回答

1条回答 默认 最新

  • dongying6896 2019-05-12 00:23
    关注

    How about something like this:

    type myLogWriter struct {
        logFunc func(string)
        line    string
    }
    
    func (w *myLogWriter) Write(b []byte) (int, error) {
        l := len(b)
        for len(b) != 0 {
            i := bytes.Index(b, []byte{'
    '})
            if i == -1 {
                w.line += string(b)
                break
            } else {
                w.logFunc(w.line + string(b[:i]))
                b = b[i+1:]
                w.line = ""
            }
        }
    
        return l, nil
    }
    
    func NewLogWriter(f func(string)) *myLogWriter {
        return &myLogWriter{
            logFunc: f,
        }
    }
    

    See https://play.golang.org/p/L6PG1gCK1er.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊
  • ¥15 安装svn网络有问题怎么办