我就廢話(huà)不多說(shuō)了,大家還是直接看代碼吧~
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")//寫(xiě)入你的命令,可以有多行,"\n"表示回車(chē)
}()
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())
補(bǔ)充:golang 執(zhí)行外部命令 超時(shí)處理 exec.CommandContext
使用exec.CommandContext來(lái)處理外部命令的超時(shí)
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))
}
運(yùn)行結(jié)果是:
ctx.Err : [context deadline exceeded]
error : [signal: killed]
out : []
如果是一個(gè)命令錯(cuò)誤輸出是什么:
下面這個(gè)例子是使用sleep不帶參數(shù),顯示是錯(cuò)誤的。
cmdarray := []string{"-c", fmt.Sprintf("%s %s", "sleep", "")}
ctx.Err : [nil>]
error : [exit status 1]
out : [usage: sleep seconds
]
可以命令的執(zhí)行錯(cuò)誤不會(huì)導(dǎo)致ctx.Err()錯(cuò)誤。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- Golang中基礎(chǔ)的命令行模塊urfave/cli的用法說(shuō)明
- golang執(zhí)行命令獲取執(zhí)行結(jié)果狀態(tài)(推薦)
- Golang命令行進(jìn)行debug調(diào)試操作
- golang中命令行庫(kù)cobra的使用方法示例
- 利用Golang如何調(diào)用Linux命令詳解
- Golang匯編命令解讀及使用