error-handling - 在 Golang 中运行 exec.Command 时如何调试 "exit status 1"错误

标签 error-handling command go exec

当我运行下面的代码时:

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())

我收到此错误:

exit status 1

但是这对于调试错误的确切原因没有帮助。

如何获取更详细的信息?

最佳答案

解决方案是使用 Command 对象的 Stderr 属性。可以这样做:

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())

运行上面的代码,可以清楚问题是什么:

exit status 1: find: -exec: no terminating ";" or "+"

编辑:

在上面的代码中,我们期望在出错的情况下,消息将被打印到 stderr 并且命令将返回一个非零错误代码。这或多或少是标准的。

但是,正如@snorberhuis 下面提到的,一些命令会将错误打印到标准输出。其他命令可能会打印到 stderr 但返回错误代码 0(在这种情况下,err 将为 nil)。在 stderr 中有消息并不一定意味着有错误(ffmpeg 工具经常这样做)。

所以基本上你可能需要调整上面的代码以适应你期望的命令。

关于error-handling - 在 Golang 中运行 exec.Command 时如何调试 "exit status 1"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18159704/

相关文章:

linux - 如何在 bash 脚本中为命令输出着色?

golang 使用 sort.Search 查找小于或等于给定元素的第一个元素

mongodb - 为什么我的更新函数返回新查询但不更新数据库?

php - 什么时候在PHP中使用@符号?

error-handling - 如果Option为Some,返回Err的惯用方式

c# - 使用 WPF 验证命令

c# - 将命令绑定(bind)到 ItemTemplate 内的按钮

PHP 到电子邮件表单 : 'spam' issue, 验证,警告框

error-handling - Nuxt 处理来自 Prismic API 的获取错误

在命令行和 Playground 上进行整数溢出设置