使用Go运行带参数的sh / bash / python脚本

时间:2014-07-12 11:25:17

标签: linux bash shell go

我几天都被困在这一天,我试图运行一个基于第一个参数的bash脚本(也许我应该放弃所有的希望,哈哈)

可以假设运行脚本的语法为:

sudo bash script argument或者因为它有og + x,所以可以只运行sudo script argument

我要按照以下方式运行它:

package main

import (
    "os"
    "os/exec"
    "fmt"
)

func main() {
    c := exec.Command("/bin/bash", "script " + argument)
    if err := c.Run(); err != nil {
        fmt.Println("Error: ", err)
    }
    os.Exit(0)
}

我绝对没有运气,我已经尝试了很多其他变种......

exec.Command("/bin/sh", "-c", "sudo script", argument)

exec.Command("/bin/sh", "-c", "sudo script " + argument)(我的第一次尝试)

exec.Command("/bin/bash", "-c", "sudo script" + argument)

exec.Command("/bin/bash", "sudo script", argument)

exec.Command("/bin/bash sudo script" + argument)

我遇到的大多数' / bin / bash sudo ect'没有这样的文件或目录,或者Error: exit status 1我甚至已经写了一个Python包装器来寻找一个参数并用子进程执行bash脚本。为了排除未定义脚本的路径,我尝试了以上所有内容,并使用了直接路由到脚本而不是脚本名称。

为了我剩下的头发,我在这里做错了什么?如何才能更好地诊断此问题,以便获取更多信息而不是退出状态1?

1 个答案:

答案 0 :(得分:2)

你根本不需要调用bash / sh,只需单独传递每个参数,也可以获取捕获命令的stderr所需的错误,这是一个有效的例子:

func main() {
    c := exec.Command("sudo", "ls", "/tmp")
    stderr := &bytes.Buffer{}
    stdout := &bytes.Buffer{}
    c.Stderr = stderr
    c.Stdout = stdout
    if err := c.Run(); err != nil {
        fmt.Println("Error: ", err, "|", stderr.String())
    } else {
        fmt.Println(stdout.String())
    }
    os.Exit(0)
}