golang執(zhí)行命令操作 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())
補(bǔ)充:golang 執(zhí)行外部命令 超時(shí)處理 exec.CommandContext
使用exec.CommandContext來處理外部命令的超時(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ò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
基于Go和PHP語言實(shí)現(xiàn)爬樓梯算法的思路詳解
這篇文章主要介紹了Go和PHP 實(shí)現(xiàn)爬樓梯算法,本文通過動(dòng)態(tài)規(guī)劃和斐波那契數(shù)列兩種解決思路給大家講解的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05go?time.After優(yōu)化后性能提升34%內(nèi)存減少67%
這篇文章主要介紹了go語言time.After優(yōu)化后性能提升34%內(nèi)存減少67%實(shí)例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02