当我运行下面的代码时:cmd := exec.Command(\'find\', \'/\', \'-maxdepth\', \'1\', \'-exec\', \'wc\', \'-c\', \'{}\', \'\\\')var out bytes.Buffercmd.Stdout = &outerr := cmd.Run()if err != nil { fmt.P...
当我运行下面的代码时:
cmd := exec.Command("find", "/", "-maxdepth", "1", "-exec", "wc", "-c", "{}", "\\")
var out bytes.Buffer
cmd.Stdout = &out
err := cmd.Run()
if err != nil {
fmt.Println(err)
return
}
fmt.Println("Result: " + out.String())
我收到此错误:
退出状态 1
但这对于调试错误的确切原因没有帮助。
如何获得更加详细的信息?
解决方案是使用 Stderr
Command 对象的属性。可以这样做:
cmd := exec.Command("find", "/", "-maxdepth", "1", "-exec", "wc", "-c", "{}", "\\")
var out bytes.Buffer
var stderr bytes.Buffer
cmd.Stdout = &out
cmd.Stderr = &stderr
err := cmd.Run()
if err != nil {
fmt.Println(fmt.Sprint(err) + ": " + stderr.String())
return
}
fmt.Println("Result: " + out.String())
运行上述代码,我们就能清楚知道问题是什么:
退出状态 1:查找:-exec:没有终止 \';\' 或 \'+\'
编辑:
在上面的代码中,我们期望在发生错误时,消息将被打印到 stderr,并且命令将返回非零错误代码。这或多或少是标准的。
但是,正如@snorberhuis 在下面提到的,有些命令会将错误打印到 stdout。其他命令可能会打印到 stderr,但返回错误代码 0(在这种情况下 err
将为 nil
)。而且 stderr 中有消息并不一定意味着有错误(ffmpeg 工具经常这样做)。
因此基本上您可能需要调整上面的代码以适应您期望的命令。