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 phython路径名过长报错 不知道什么问题
  • ¥15 深度学习中模型转换该怎么实现
  • ¥15 HLs设计手写数字识别程序编译通不过
  • ¥15 Stata外部命令安装问题求帮助!
  • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
  • ¥15 TYPCE母转母,插入认方向
  • ¥15 如何用python向钉钉机器人发送可以放大的图片?
  • ¥15 matlab(相关搜索:紧聚焦)
  • ¥15 基于51单片机的厨房煤气泄露检测报警系统设计