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

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

EC99 1月前

19 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 工具经常这样做)。

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

返回
作者最近主题: