同时将命令输出写入控制台和日志文件
您希望将命令的输出重定向到控制台和日志文件。现有代码将输出发送到控制台,但不记录它。要重定向两个流,请使用下面描述的技术。
要实现您的目标,请考虑以下方法:
将 Stdout 和 Stderr 重定向到 MultiWriter
创建一个结合文件和标准输出的MultiWriter。然后,在运行命令之前,将此 MultiWriter 分配给命令的 Stdout 和 Stderr 流。
示例代码
<code class="go">package main import ( "io" "log" "os" "os/exec" ) func main() { // Open the log file for writing f, err := os.OpenFile("log.log", os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666) if err != nil { log.Fatalf("Error opening file: %v", err) } defer f.Close() // Create a MultiWriter that combines the log file and standard output mwriter := io.MultiWriter(f, os.Stdout) // Construct the command cmd := exec.Command("ls") // Redirect Stdout and Stderr to the MultiWriter cmd.Stdout = mwriter cmd.Stderr = mwriter // Run the command err = cmd.Run() if err != nil { panic(err) } }</code>
此代码打开一个日志文件,创建一个MultiWriter,将命令的流设置为 MultiWriter,并运行命令。输出将按正确的顺序实时重定向到控制台和日志文件。
以上是如何将命令输出同时写入控制台和日志文件?的详细内容。更多信息请关注PHP中文网其他相关文章!