8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

如何在 Golang 中运行 exec.Command 时调试“退出状态 1”错误

EC99 1月前

14 0

当我运行下面的代码时: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

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

如何获得更加详细的信息?

帖子版权声明 1、本帖标题:如何在 Golang 中运行 exec.Command 时调试“退出状态 1”错误
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由EC99在本站《go》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 解决方案是使用 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 工具经常这样做)。

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

  • 您的解决方案对调试非常有帮助,但我不得不做一些小改动才能真正看到输出。我正在调试 Windows 关机命令,退出状态也是 1。这会打印到 Stdout。所以我将最后一行打印移到了 if 语句上方。

  • 此解决方案比 CombinedOutput() 更好,因为在这里我们可以获得详细的错误文本(cmd.Stderr 的)。在输出中,err := cmd.CombinedOutput() ,输出确实包含错误文本,但它与 err 相同。

  • 正如 Laurent 提到的,您可以覆盖 Stderr 文件描述符以捕获 stderr 输出,以获得更好的错误消息。 CombinedOutput 如果要执行相对简单的事情,我个人更喜欢使用命令方法:

    cmd := exec.Command("find", "/", "-maxdepth", "1", "-exec", "wc", "-c", "{}", "\\")
    output, err := cmd.CombinedOutput()
    if err != nil {
        fmt.Println(fmt.Sprint(err) + ": " + string(output))
        return
    }
    fmt.Println(string(output))
    

    这是上述示例的 play.golang.org 链接: http://play.golang.org/p/z8k9zO755P

返回
作者最近主题: