2 回答
TA贡献1780条经验 获得超5个赞
这就是我最终做到的
m := map[string]*log.Logger{
config.Process.TraceLog: Trace,
config.Process.InfoLog: Info,
config.Process.WarningLog: Warning,
config.Process.ErrorLog: Error,
}
for filepath, l := range m {
if filepath != "" {
f, err := os.OpenFile(filepath, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666)
if err != nil {
fmt.Println("error opening log file: %v", err)
os.Exit(1)
}
l.SetOutput(f)
}
}
TA贡献1909条经验 获得超7个赞
这样的事情可能会起作用(您可能需要调整界面中的函数类型或完全删除界面):
setLogIfNotEmpty(config.Process.TraceLog, Trace)
setLogIfNotEmpty(config.Process.InfoLog, Info)
setLogIfNotEmpty(config.Process.WarningLog, Warning)
setLogIfNotEmpty(config.Process.ErrorLog, Error)
interface SetOutputer {
SetOutput(*os.File)
}
func setLogIfNotEmpty(file string, log SetOutputer) {
if file != "" {
f, err := os.OpenFile(file, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666)
if err != nil {
fmt.Println("error opening log file: %v", err)
os.Exit(1)
}
log.SetOutput(f)
}
}
- 2 回答
- 0 关注
- 139 浏览
添加回答
举报