利用Golang如何調(diào)用Linux命令詳解
本文介紹的是Golang使用 os/exec 來執(zhí)行 Linux 命令,分享出來供大家參考學(xué)習(xí),下面來看看詳細(xì)的介紹:
下面是一個(gè)簡(jiǎn)單的示例:
package main import ( "fmt" "io/ioutil" "os/exec" ) func main() { cmd := exec.Command("/bin/bash", "-c", `df -lh`) //創(chuàng)建獲取命令輸出管道 stdout, err := cmd.StdoutPipe() if err != nil { fmt.Printf("Error:can not obtain stdout pipe for command:%s\n", err) return } //執(zhí)行命令 if err := cmd.Start(); err != nil { fmt.Println("Error:The command is err,", err) return } //讀取所有輸出 bytes, err := ioutil.ReadAll(stdout) if err != nil { fmt.Println("ReadAll Stdout:", err.Error()) return } if err := cmd.Wait(); err != nil { fmt.Println("wait:", err.Error()) return } fmt.Printf("stdout:\n\n %s", bytes) }
或者創(chuàng)建一個(gè)緩沖讀取器按行讀?。?/strong>
package main import ( "bufio" "fmt" "os/exec" ) func main() { cmd := exec.Command("/bin/bash", "-c", `df -lh`) //創(chuàng)建獲取命令輸出管道 stdout, err := cmd.StdoutPipe() if err != nil { fmt.Printf("Error:can not obtain stdout pipe for command:%s\n", err) return } //執(zhí)行命令 if err := cmd.Start(); err != nil { fmt.Println("Error:The command is err,", err) return } //使用帶緩沖的讀取器 outputBuf := bufio.NewReader(stdout) for { //一次獲取一行,_ 獲取當(dāng)前行是否被讀完 output, _, err := outputBuf.ReadLine() if err != nil { // 判斷是否到文件的結(jié)尾了否則出錯(cuò) if err.Error() != "EOF" { fmt.Printf("Error :%s\n", err) } return } fmt.Printf("%s\n", string(output)) } //wait 方法會(huì)一直阻塞到其所屬的命令完全運(yùn)行結(jié)束為止 if err := cmd.Wait(); err != nil { fmt.Println("wait:", err.Error()) return } }
輸出結(jié)果:
在寫這句 if err.Error() != "EOF"
時(shí),一直以為可以直接將 error 類型直接轉(zhuǎn)為 string 然后就可以比較了,所以剛開始寫的代碼是這樣的 if string(err) != "EOF"
,但是一直報(bào)下面這個(gè)錯(cuò)誤:
# command-line-arguments ./exec_command.go:36: cannot convert err (type error) to type string
于是查了下才明白,error 類型本身是一個(gè)預(yù)定義好的接口,里面定義了一個(gè)method:
type error interface { Error() string }
所以 err.Error()
才是一個(gè) string 類型的返回值。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
go語(yǔ)言處理TCP拆包/粘包的具體實(shí)現(xiàn)
TCP的拆包/粘包也算是網(wǎng)絡(luò)編程中一個(gè)比較基礎(chǔ)的問題了,本文主要介紹了go語(yǔ)言處理TCP拆包/粘包,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12Golang實(shí)現(xiàn)對(duì)map的并發(fā)讀寫的方法示例
這篇文章主要介紹了Golang實(shí)現(xiàn)對(duì)map的并發(fā)讀寫的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-03-03深入理解Go高級(jí)并發(fā)模式編寫更高效可擴(kuò)展的應(yīng)用程序
Go對(duì)并發(fā)提供了強(qiáng)大的原生支持,本文討論Go的高級(jí)并發(fā)模式,理解這些并發(fā)模式,可以幫助我們編寫高效的Go應(yīng)用程序,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-02-02Golang簡(jiǎn)介與基本語(yǔ)法的學(xué)習(xí)
這篇文章主要介紹了Golang簡(jiǎn)介與基本語(yǔ)法的學(xué)習(xí),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04淺析Go語(yǔ)言如何在select語(yǔ)句中實(shí)現(xiàn)優(yōu)先級(jí)
這篇文章主要為大家詳細(xì)介紹了Go語(yǔ)言如何在select語(yǔ)句中實(shí)現(xiàn)優(yōu)先級(jí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-03-03