我就废话不多说了,大家还是直接看代码吧~
cmd := exec.Command("cmd")
in := bytes.NewBuffer(nil)
cmd.Stdin = in//绑定输入
var out bytes.Buffer
cmd.Stdout = &out //绑定输出
go func() {
in.WriteString("node E:/design/test.js\n")//写入你的命令,可以有多行,"\n"表示回车
}()
err = cmd.Start()
if err != nil {
log.Fatal(err)
}
log.Println(cmd.Args)
err = cmd.Wait()
if err != nil {
log.Printf("Command finished with error: %v", err)
}
fmt.Println(out.String())
补充:golang 执行外部命令 超时处理 exec.CommandContext
使用exec.CommandContext来处理外部命令的超时
func main() {
timeout := 5
ctx, cancel := context.WithTimeout(context.Background(), time.Duration(timeout+5)*time.Second)
defer cancel()
cmdarray := []string{"-c", fmt.Sprintf("%s %s", "sleep", "10")}
cmd := exec.CommandContext(ctx, "bash", cmdarray...)
out, err := cmd.CombinedOutput()
//if ctx.Err() == context.DeadlineExceeded {}
fmt.Printf("ctx.Err : [%v]\n", ctx.Err())
fmt.Printf("error : [%v]\n", err)
fmt.Printf("out : [%s]\n", string(out))
}
运行结果是:
ctx.Err : [context deadline exceeded]
error : [signal: killed]
out : []
如果是一个命令错误输出是什么:
下面这个例子是使用sleep不带参数,显示是错误的。
cmdarray := []string{"-c", fmt.Sprintf("%s %s", "sleep", "")}
ctx.Err : [<nil>]
error : [exit status 1]
out : [usage: sleep seconds
]
可以命令的执行错误不会导致ctx.Err()错误。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持软件开发网。如有错误或未考虑完全的地方,望不吝赐教。
您可能感兴趣的文章:golang文件服务器的两种方式(可以访问任何目录)对Golang中的runtime.Caller使用说明如何判断Golang接口是否实现的操作浅谈golang中的&^位清空操作Golang之defer 延迟调用操作解决golang sync.Wait()不执行的问题Golang获取目录下的文件及目录信息操作