在golang中如何将exec.Cmd的stdout写入文件?

jer*_*son 24 file-io go

我正在尝试运行shell命令,捕获stdout并将该输出写入文件.但是,我似乎错过了几个步骤,因为当程序存在时,我试图写的文件是空的.如何捕获命令的标准输出并将其写入文件?

package main

import (
    "bufio"
    "io"
    "os"
    "os/exec"
)

func main() {

    cmd := exec.Command("echo", "'WHAT THE HECK IS UP'")

    // open the out file for writing
    outfile, err := os.Create("./out.txt")
    if err != nil {
        panic(err)
    }
    defer outfile.Close()

    stdoutPipe, err := cmd.StdoutPipe()
    if err != nil {
        panic(err)
    }

    writer := bufio.NewWriter(outfile)

    err = cmd.Start()
    if err != nil {
        panic(err)
    }

    go io.Copy(writer, stdoutPipe)
    cmd.Wait()
}
Run Code Online (Sandbox Code Playgroud)

jer*_*son 40

感谢#go-nutsirc频道上的KirkMcDonald ,我通过分配输出文件来解决这个问题cmd.Stdout,这意味着stdout直接写入文件.它看起来像这样:

package main

import (
    "os"
    "os/exec"
)

func main() {

    cmd := exec.Command("echo", "'WHAT THE HECK IS UP'")

    // open the out file for writing
    outfile, err := os.Create("./out.txt")
    if err != nil {
        panic(err)
    }
    defer outfile.Close()
    cmd.Stdout = outfile

    err = cmd.Start(); if err != nil {
        panic(err)
    }
    cmd.Wait()
}
Run Code Online (Sandbox Code Playgroud)

  • 这真是太好了。如果您使用“cmd.Run()”,则不需要在最后发出“cmd.Wait()”,因为“Run”是阻塞的。 (2认同)

Klu*_*uyg 16

你需要刷新作者.添加以下内容:

    writer := bufio.NewWriter(outfile)
    defer writer.Flush()
Run Code Online (Sandbox Code Playgroud)


小智 10

您还可以使用:

cmd.Stdout = os.Stdout
Run Code Online (Sandbox Code Playgroud)

它会将所有cmd输出重定向到OS的标准输出.

  • “操作系统的标准输出”实际上是父进程的“stdout”,而不是“操作系统”。另外,默认情况下,即如果程序对“cmd.Stdout”和“cmd.Stderr”不执行任何操作,则子进程“stdout”和“stderr”将转到父进程“stdout”和“stderr”。 (2认同)