• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            Fork me on GitHub
            隨筆 - 215  文章 - 13  trackbacks - 0
            <2017年11月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789


            專注即時通訊及網游服務端編程
            ------------------------------------
            Openresty 官方模塊
            Openresty 標準模塊(Opm)
            Openresty 三方模塊
            ------------------------------------
            本博收藏大部分文章為轉載,并在文章開頭給出了原文出處,如有再轉,敬請保留相關信息,這是大家對原創作者勞動成果的自覺尊重!!如為您帶來不便,請于本博下留言,謝謝配合。

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 216742
            • 排名 - 118

            最新評論

            閱讀排行榜

            https://blog.csdn.net/windvix/article/details/44222629

            Golang運行cmd命令逐行實時輸出執行過程,注意,不是一次輸出所有的內容,而是按照執行的過程,逐行逐行的實時顯示出來

            代碼如下:

            package main
             
            import (
                "bufio"
                "fmt"
                "io"
                "os/exec"
            )
             
            func main() {
                command := "ls"
                params := []string{"-l"}
                //執行cmd命令: ls -l
                execCommand(command, params)
            }
             
            func execCommand(commandName stringparams []stringbool {
                cmd := exec.Command(commandName, params)
             
                //顯示運行的命令
                fmt.Println(cmd.Args)
             
                stdout, err := cmd.StdoutPipe()
             
                if err != nil {
                    fmt.Println(err)
                    return false
                }
                
                cmd.Start()
             
                reader := bufio.NewReader(stdout)
             
                //實時循環讀取輸出流中的一行內容
                for {
                    line, err2 := reader.ReadString('\n')
                    if err2 != nil || io.EOF == err2 {
                        break
                    }
                    fmt.Println(line)
                }
             
                cmd.Wait()
                return true
            }

            編譯運行效果如圖:


            http://www.tianfeiyu.com/?p=2673

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

            1. package main
            2. import (
            3. "fmt"
            4. "io/ioutil"
            5. "os/exec"
            6. )
            7. func main() {
            8. cmd := exec.Command("/bin/bash", "-c", `df -lh`)
            9. //創建獲取命令輸出管道
            10. stdout, err := cmd.StdoutPipe()
            11. if err != nil {
            12. fmt.Printf("Error:can not obtain stdout pipe for command:%s\n", err)
            13. return
            14. }
            15. //執行命令
            16. if err := cmd.Start(); err != nil {
            17. fmt.Println("Error:The command is err,", err)
            18. return
            19. }
            20. //讀取所有輸出
            21. bytes, err := ioutil.ReadAll(stdout)
            22. if err != nil {
            23. fmt.Println("ReadAll Stdout:", err.Error())
            24. return
            25. }
            26. if err := cmd.Wait(); err != nil {
            27. fmt.Println("wait:", err.Error())
            28. return
            29. }
            30. fmt.Printf("stdout:\n\n %s", bytes)
            31. }

            或者創建一個緩沖讀取器按行讀取:

            1. package main
            2. import (
            3. "bufio"
            4. "fmt"
            5. "os/exec"
            6. )
            7. func main() {
            8. cmd := exec.Command("/bin/bash", "-c", `df -lh`)
            9. //創建獲取命令輸出管道
            10. stdout, err := cmd.StdoutPipe()
            11. if err != nil {
            12. fmt.Printf("Error:can not obtain stdout pipe for command:%s\n", err)
            13. return
            14. }
            15. //執行命令
            16. if err := cmd.Start(); err != nil {
            17. fmt.Println("Error:The command is err,", err)
            18. return
            19. }
            20. //使用帶緩沖的讀取器
            21. outputBuf := bufio.NewReader(stdout)
            22. for {
            23. //一次獲取一行,_ 獲取當前行是否被讀完
            24. output, _, err := outputBuf.ReadLine()
            25. if err != nil {
            26.  
            27. // 判斷是否到文件的結尾了否則出錯
            28. if err.Error() != "EOF" {
            29. fmt.Printf("Error :%s\n", err)
            30. }
            31. return
            32. }
            33. fmt.Printf("%s\n", string(output))
            34. }
            35. //wait 方法會一直阻塞到其所屬的命令完全運行結束為止
            36. if err := cmd.Wait(); err != nil {
            37. fmt.Println("wait:", err.Error())
            38. return
            39. }
            40. }

            輸出結果:

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

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

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

            1. type error interface {
            2. Error() string
            3. }
              //
               err.Error() 才是一個 string 類型的返回值。
            posted on 2018-10-09 16:09 思月行云 閱讀(1195) 評論(0)  編輯 收藏 引用 所屬分類: Golang
            亚洲国产天堂久久久久久| 欧美激情一区二区久久久| 精品国产一区二区三区久久久狼| 亚洲AV成人无码久久精品老人| 久久精品国产男包| 热re99久久精品国产99热| 婷婷久久综合| 香蕉久久一区二区不卡无毒影院| 国产亚洲色婷婷久久99精品91| 色婷婷综合久久久久中文字幕 | 中文精品99久久国产| 色综合久久无码五十路人妻| 国产成人久久精品二区三区| 99久久国产综合精品女同图片 | 亚洲欧美国产精品专区久久| 97热久久免费频精品99| 四虎影视久久久免费| 99久久精品毛片免费播放| 伊人伊成久久人综合网777| 成人亚洲欧美久久久久| 久久Av无码精品人妻系列| 亚洲国产天堂久久综合| 狠狠精品久久久无码中文字幕 | 久久国产乱子伦精品免费强| 久久久精品人妻一区二区三区蜜桃| 精品久久久久久国产| 国产Av激情久久无码天堂| 中文无码久久精品| 蜜桃麻豆WWW久久囤产精品| 久久精品国产欧美日韩| 久久国产视频网| 一本一道久久精品综合| a级成人毛片久久| 久久精品无码专区免费东京热| 2021久久精品免费观看| 久久国产欧美日韩精品免费| 亚洲欧美久久久久9999 | 狠狠久久综合| 亚洲а∨天堂久久精品| 狠狠色丁香婷婷久久综合五月| 久久人人爽人人爽AV片|