• <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
            久久婷婷久久一区二区三区| 国产亚洲欧美精品久久久| 久久99精品久久久久久hb无码| 久久久久18| 久久综合给合综合久久| 无码久久精品国产亚洲Av影片| 久久国产成人精品麻豆| 久久精品国产清自在天天线| 久久综合亚洲欧美成人| 久久久久一本毛久久久| 波多野结衣久久一区二区 | 国产精品美女久久久免费| 午夜天堂av天堂久久久| 久久亚洲国产欧洲精品一| 2021久久精品免费观看| 亚洲国产精品久久久久婷婷软件| 日本五月天婷久久网站| 久久精品国产亚洲av麻豆小说| 中文字幕日本人妻久久久免费 | 久久久噜噜噜久久中文字幕色伊伊| 久久精品午夜一区二区福利| 久久影院亚洲一区| 国产精品久久波多野结衣| 热re99久久6国产精品免费| 久久成人18免费网站| 国产精品久久久天天影视香蕉 | 久久久久久精品免费看SSS| 久久国产乱子精品免费女| 狠狠综合久久综合88亚洲| 久久性精品| 久久久久久一区国产精品| 久久伊人精品青青草原高清| 久久久久99精品成人片欧美 | 久久人人爽人人人人片av| 狠狠人妻久久久久久综合蜜桃| 国产婷婷成人久久Av免费高清| 综合久久国产九一剧情麻豆| 三级三级久久三级久久| 99久久综合国产精品免费| 三级三级久久三级久久 | 成人妇女免费播放久久久|