知識點 exec

知識點:【http傳輸】respBodyMap := bson.M{"狀態碼": "成功", "userId": userId, "dataSource": dataSource, "upDown": upDown, "channel": channel, "full": full, "文件詳細信息": fileInfoStrSlice}buf, err := json.Marshal(respBodyMap)var TranspondServerUrlPath string = `http://10.60.73.152:8087/transpond/`//transpond爲註冊路由器的socket,8087爲監聽的端口resp, err := http.Post(TranspondServerUrlPath+"TranspondAutoGetData", "application/json", bytes.NewReader(buf))defer resp.Body.Close()body, err := ioutil.ReadAll(resp.Body)var data interface{}err = json.Unmarshal(body, &data)status := data.(map[string]interface{})["狀態碼"].(string)【go調用Python】matlabPath := "D:\\scw\\dingheng\\V2.00.20_0709_p\\HFC_UL.m"files, _ := ioutil.ReadDir("D:\\scw\\json_Tmp")for k, fi := range files {   cmd1 := exec.Command("python", "callMatlab.py", fi.Name(), matlabPath)//go調用python   cmd1.Dir = "D:\\scw\\dingheng\\V2.00.20_0709_p"   err := cmd1.Start()   if err != nil {      fmt.Println("err", err)   } else {         errWait := cmd1.Wait()         if errWait != nil { //exit status 1            fmt.Println("ss err", errWait)         }      }}python代碼/*# -*- coding: utf-8 -*-from pymatbridge import Matlabimport sysif __name__ == '__main__':   jsonName = sys.argv[1].strip("'")   print jsonName   mlab = Matlab()   mlab.start()   mlab.set_plot_settings(width = 1200,height = 900,inline = True)   res = mlab.run_func("D:\\scw\\dingheng\\V2.00.20_0709_p\\HFC_UL.m",{'arg1':jsonName,'arg2':"",'arg3':""})   print res*/【os/exec】//先經過系統庫exec.LookPath判斷可執行程序是否存在path, err := exec.LookPath(exe)//exe能夠爲"ls","bee"調用腳本文件cmd := exec.Command("taskkill.exe", "/f", "/t", "/im", "nginx.exe")err = cmd.Start()if nil != err {   log.Error("pkg: service, func: KillNginxServer, method: cmd.Start, errInfo:", err)} else {   log.Info(fmt.Sprintf("kill %s successfully", "nginx.exe"))}time.Sleep(3 * time.Second) //必需要暫停獲取本地IPfunc GetLocalIP() {   buf, err := exec.Command("CMD", "/C", " ipconfig").Output()   fmt.Println("buf", string(buf))   if err != nil {      fmt.Println("pkg: service, func: GetLocalIP, method: exec.Command, errInfo:", err)   return   }   reg := regexp.MustCompile(`\d+\.\d+\.\d+\.\d+`)   ips := reg.FindAllString(string(buf), -1)   for _, ip := range ips {      fmt.Println("LocalIp", ip)   }   return}exec.Command("CMD", "/C", " ipconfig")cmd /c dir 是執行完dir命令後封閉命令窗口cmd /k dir 是執行完dir命令後不封閉命令窗口cmd /c dir 會打開一個新窗口後執行dir命令,原窗口會封閉cmd /k dir 會打開一個新窗口後執行dir命令,原窗口不會封閉cmd := exec.Command("touch", "test_file")err := cmd.Run()if err != nil {   fmt.Println("Execute Command failed:" + err.Error())   return}fmt.Println("Execute Command finished.")command := `./dir_size.sh .`cmd := exec.Command("/bin/bash", "-c", command)output, err := cmd.Output()if err != nil {   fmt.Printf("Execute Shell:%s failed with error:%s", command, err.Error())return}fmt.Printf("Execute Shell:%s finished with output:\n%s", command, string(output))func Command(name string, arg ...string) *Cmd//方法返回一個*Cmd, 用於執行name指定的程序(攜帶arg參數)func (c *Cmd) Run() error//執行Cmd中包含的命令,阻塞直到命令執行完成func (c *Cmd) Start() error//執行Cmd中包含的命令,該方法當即返回,並不等待命令執行完成func (c *Cmd) Wait() error//該方法會阻塞直到Cmd中的命令執行完成,但該命令必須是被Start方法開始執行的func (c *Cmd) Output() ([]byte, error)//執行Cmd中包含的命令,並返回標準輸出的切片func (c *Cmd) CombinedOutput() ([]byte, error)//執行Cmd中包含的命令,並返回標準輸出與標準錯誤合併後的切片func (c *Cmd) StdinPipe() (io.WriteCloser, error)//返回一個管道,該管道會在Cmd中的命令被啓動後鏈接到其標準輸入func (c *Cmd) StdoutPipe() (io.ReadCloser, error)//返回一個管道,該管道會在Cmd中的命令被啓動後鏈接到其標準輸出func (c *Cmd) StderrPipe() (io.ReadCloser, error)//返回一個管道,該管道會在Cmd中的命令被啓動後鏈接到其標準錯誤type Cmd struct {Path         string //運行命令的路徑,絕對路徑或者相對路徑Args         []string // 命令參數Env          []string //進程環境,若是環境爲空,則使用當前進程的環境Dir          string//指定command的工做目錄,若是dir爲空,則comman在調用進程所在當前目錄中運行Stdin        io.Reader//標準輸入,若是stdin是nil的話,進程從null device中讀取(os.DevNull),stdin也能夠時一個文件,不然的話則在運行過程當中再開一個goroutine去Stdout       io.Writer //標準輸出Stderr       io.Writer //錯誤輸出,若是這兩個(Stdout和Stderr)爲空的話,則command運行時將響應的文件描述符鏈接到os.DevNullExtraFiles   []*os.FileSysProcAttr  *syscall.SysProcAttrProcess      *os.Process    //Process是底層進程,只啓動一次ProcessState *os.ProcessState //ProcessState包含一個退出進程的信息,當進程調用Wait或者Run時便會產生該信息.}func Command(name string, arg ...string) *Cmd //command返回cmd結構來執行帶有相關參數的命令,它僅僅設定cmd結構中的Path和Args參數,// 若是name參數中不包含路徑分隔符,command使用LookPath來解決路徑問題,不然的話就直接使用name;Args直接跟在command命令以後,因此在Args中不準要添加命令.cmd := exec.Command("tr", "a-z", "A-Z")cmd.Stdin = strings.NewReader("some input")var out bytes.Buffercmd.Stdout = &outerr := cmd.Run()if err != nil {log.Fatal(err)}fmt.Printf("in all caps: %q\n", out.String()) //in all caps: "SOME INPUT"func (c *Cmd) CombinedOutput() ([]byte, error) //運行命令,並返回標準輸出和標準錯誤cmd := exec.Command("ls")  //查看當前目錄下文件out, err := cmd.CombinedOutput()if err != nil {fmt.Println(err)}fmt.Println(string(out))func (c *Cmd) Output() ([]byte, error) //運行命令並返回其標準輸出cmd := exec.Command("ls") ///查看當前目錄下文件out, err := cmd.Output()if err != nil {fmt.Println(err)}fmt.Println(string(out))注意:Output()和CombinedOutput()不可以同時使用,由於command的標準輸出只能有一個,同時使用的話便會定義了兩個,便會報錯func (c *Cmd) Run() error//開始指定命令而且等待他執行結束,若是命令可以成功執行完畢,則返回nil,不然的話邊會產生錯誤func (c *Cmd) Start() error//使某個命令開始執行,可是並不等到他執行結束,這點和Run命令有區別.而後使用Wait方法等待命令執行完畢而且釋放響應的資源注:一個command只能使用Start()或者Run()中的一個啓動命令,不能兩個同時使用.func (c *Cmd) Wait() error//Wait等待command退出,他必須和Start一塊兒使用,若是命令可以順利執行完並順利退出則返回nil,不然的話便會返回error,其中Wait會是放掉全部與cmd命令相關的資源另外一種形式cmd := exec.Command("cmd")in := bytes.NewBuffer(nil)cmd.Stdin = in//綁定輸入var out bytes.Buffercmd.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())
相關文章
相關標籤/搜索