golang執行命令操作 exec.Command

我就廢話不多說瞭,大傢還是直接看代碼吧~

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()錯誤。

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。

推薦閱讀: