Golang 調(diào)用 Linux 命令

Golang 中可以使用 os/exec 來執(zhí)行 Linux 命令,下面是一個簡單的示例:

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)建一個緩沖讀取器按行讀?。?/p>

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é)尾了否則出錯
            if err.Error() != "EOF" {
                fmt.Printf("Error :%s\n", err)
            }
            return
        }
        fmt.Printf("%s\n", string(output))
    }

    //wait 方法會一直阻塞到其所屬的命令完全運行結(jié)束為止
    if err := cmd.Wait(); err != nil {
        fmt.Println("wait:", err.Error())
        return
    }
}

輸出結(jié)果:

在寫這句 if err.Error() != "EOF" 時,一直以為可以直接將 error 類型直接轉(zhuǎn)為 string 然后就可以比較了,所以剛開始寫的代碼是這樣的 if string(err) != "EOF",但是一直報下面這個錯誤:

# command-line-arguments
./exec_command.go:36: cannot convert err (type error) to type string

于是查了下才明白,error 類型本身是一個預(yù)定義好的接口,里面定義了一個method

type error interface {
    Error() string
}

所以 err.Error() 才是一個 string 類型的返回值。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 能力模型 選擇題 [primary] 下面屬于關(guān)鍵字的是()A. funcB. defC. structD. cl...
    _張曉龍_閱讀 25,121評論 14 224
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,525評論 19 139
  • 談到docker源碼,其實網(wǎng)上有很多的源碼的分析的文章,也看過一些大牛寫的docker源碼解讀的文章,收獲很大。我...
    跨界師閱讀 1,437評論 2 3
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,633評論 18 399
  • 已經(jīng)過去14年了吧,也曾矛盾過,我對過去青春的后悔。 那是一個細雨蒙蒙的下午,操場上還未干透,他拿著籃球...
    別滋味閱讀 324評論 1 0

友情鏈接更多精彩內(nèi)容