我就废话不多说了,大家还是直接看代码吧~

  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()错误。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

您可能感兴趣的文章: