您好,登錄后才能下訂單哦!
本篇內容介紹了“Go語言的exec怎么使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
Exec 是 os 包中的一個子包,它可用于使用 Go 運行外部命令。Go exec 命令教程展示了如何在 Golang 中執行 shell 命令和程序。
要使用這個包,我們需要按如下方式導入:
import "os/exec"
我們可以運行任何我們希望的命令。就像我們使用 CMD、bash 或其他一些 shell 來運行命令一樣,它可以運行這些命令。
這是運行 ls 命令的示例。新建一個 main.go :
package main import ( "fmt" "os/exec" ) func main() { cmd := exec.Command("ls") e := cmd.Run() CheckError(e) } func CheckError(e error) { if e != nil { fmt.Println(e) } }
Run 函數啟動指定命令并等待它完成,而 Start 啟動指定命令但不等待它完成;我們需要使用Wait with Start。
然后新建一個 go.mod 文件:
$ go mod init main.go go: creating new go.mod: module main.go go: to add module requirements and sums: go mod tidy
現在,程序將運行,但我們不會看到控制臺的任何輸出。原因是命令運行,輸出沒有發送到標準輸出。
$ go run main.go
所以,我們需要修復它。添加下面顯示的兩行以查看控制臺的任何輸出。
cmd.Stdout = os.Stdout cmd.Stderr = os.Stderr
輸出將顯示當前目錄中的文件。
package main import ( "fmt" "os" "os/exec" ) func main() { cmd := exec.Command("ls", "-lah") cmd.Stdout = os.Stdout cmd.Stderr = os.Stderr e := cmd.Run() CheckError(e) } func CheckError(e error) { if e != nil { fmt.Println(e) } }
然后我們再程序,可以看到標準臺輸出如下的文件:
$ go run main.go total 16 drwxr-xr-x 4 yuzhou_1su staff 128B 5 15 22:56 . drwxr-xr-x 23 yuzhou_1su staff 736B 5 15 22:53 .. -rw-r--r-- 1 yuzhou_1su staff 24B 5 15 22:56 go.mod -rw-r--r-- 1 yuzhou_1su staff 248B 5 15 23:18 main.go
利用直接 ls 直接運行該命令,可以看到結果正確:
$ ls -alh total 16 drwxr-xr-x 4 yuzhou_1su staff 128B 5 15 22:56 . drwxr-xr-x 23 yuzhou_1su staff 736B 5 15 22:53 .. -rw-r--r-- 1 yuzhou_1su staff 24B 5 15 22:56 go.mod -rw-r--r-- 1 yuzhou_1su staff 248B 5 15 23:18 main.go
我們可以指定針對不同操作系統運行不同的命令(例如 Linux 上的 bash 命令)。這是一個例子。
if runtime.GOOS == "linux" { cmd = exec.Command("ls") }
為此,我們還需要導入運行時包。
要查看所有可能的操作系統,我們可以運行 go tool dist list ,它將顯示所有可能的操作系統和 ARCH 組合。
輸出運行命令并返回其標準輸出:
package main import ( "fmt" "log" "os/exec" ) func main() { out, err := exec.Command("ls", "-l").Output() if err != nil { log.Fatal(err) } fmt.Println(string(out)) }
運行該程序:
$ go run main.go total 16 -rw-r--r-- 1 yuzhou_1su staff 24 5 15 22:56 go.mod -rw-r--r-- 1 yuzhou_1su staff 180 5 15 23:33 main.go
管道允許我們將一個命令的輸出發送到另一個命令。 StdinPipe 返回一個管道,該管道將在命令啟動時連接到命令的標準輸入。
package main import ( "fmt" "io" "log" "os/exec" ) func main() { cmd := exec.Command("cat") stdin, err := cmd.StdinPipe() if err != nil { log.Fatal(err) } go func() { defer stdin.Close() io.WriteString(stdin, "an old falcon") }() out, err := cmd.CombinedOutput() if err != nil { log.Fatal(err) } fmt.Printf("%s\n", out) }
在代碼示例中,我們將字符串寫入 goroutine 內的標準輸入。
cmd := exec.Command("cat")
cat 命令將給定的文件連接到標準輸出。當沒有給定文件或帶有 - 時,該命令讀取標準輸入并將其打印到標準輸出。
stdin, err := cmd.StdinPipe()
我們得到 cat 命令的標準輸入管道。
go func() { defer stdin.Close() io.WriteString(stdin, "an old falcon") }()
在 goroutine 內部,我們將一個字符串寫入標準輸入管道。
$ go run stdinpipe.go an old falcon
StdoutPipe 返回一個管道,該管道將在命令啟動時連接到命令的標準輸出。
package main import ( "fmt" "io/ioutil" "log" "os/exec" "strings" ) func upper(data string) string { return strings.ToUpper(data) } func main() { cmd := exec.Command("echo", "an old falcon") stdout, err := cmd.StdoutPipe() if err != nil { log.Fatal(err) } if err := cmd.Start(); err != nil { log.Fatal(err) } data, err := ioutil.ReadAll(stdout) if err != nil { log.Fatal(err) } if err := cmd.Wait(); err != nil { log.Fatal(err) } fmt.Printf("%s\n", upper(string(data))) }
該示例通過管道讀取 echo 命令的輸出并將其轉換為大寫字母。
cmd := exec.Command("echo", "an old falcon")
要運行的命令是帶有單個字符串參數的 echo 命令。
stdout, err := cmd.StdoutPipe()
我們得到標準輸出管道。
if err := cmd.Start(); err != nil { log.Fatal(err) }
該命令使用 Start 函數執行;它不會等待它完成。
data, err := ioutil.ReadAll(stdout)
我們從管道中讀取數據。
if err := cmd.Wait(); err != nil { log.Fatal(err) }
Wait 等待命令退出并等待任何復制到 stdin 或從 stdout 或 stderr 復制完成。它在看到命令退出后關閉管道。
運行該程序:
$ go run stdoutpipe.go AN OLD FALCON
“Go語言的exec怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。