如何从exec命令获取错误消息

时间:2018-12-14 11:47:27

标签: go cmd operating-system exec

我正在使用Go创建一个CLI。我正在执行命令,如果从操作系统抛出错误,则要打印它。

cmd := exec.Command("abc", "run", pathToFile)
err := cmd.Start()
if err != nil {
    fmt.Printf("Error : %v \n", err)
    os.Exit(1)
}
err = cmd.Wait()
if err != nil {
    fmt.Printf("Error: %v \n", err)
    os.Exit(1)
}

这只会给我退出状态代码

Error:  exit status 1 

这还不够说明性。

直接在终端中运行命令时,我会清楚地收到错误消息。

source does not exist 'test.exe'

是否可以打印消息?

1 个答案:

答案 0 :(得分:6)

StderrPipe返回一条管道,该管道将在命令启动时连接到命令的标准错误。

cmd := exec.Command("abc", "run", pathToFile)
stderr, _ := cmd.StderrPipe()
if err := cmd.Start(); err != nil {
    log.Fatal(err)
}

scanner := bufio.NewScanner(stderr)
for scanner.Scan() {
    fmt.Println(scanner.Text())
}