• <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年6月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678


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

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 215662
            • 排名 - 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 思月行云 閱讀(1191) 評論(0)  編輯 收藏 引用 所屬分類: Golang
            久久久久久国产精品免费无码| 99久久免费只有精品国产| 亚洲人成网站999久久久综合| 欧美成人免费观看久久| 久久久久亚洲AV无码专区首JN| 99久久精品国产一区二区| 国产精品久久成人影院| 天堂无码久久综合东京热| 亚洲AV无码1区2区久久| 久久精品国产精品亚洲人人| 久久人人爽人人爽人人片AV东京热 | 精品久久久无码中文字幕| 色综合久久夜色精品国产| 国产∨亚洲V天堂无码久久久| 久久精品成人一区二区三区| 三上悠亚久久精品| 久久99精品久久久久久9蜜桃| 久久夜色精品国产噜噜麻豆 | 精品久久久久久国产91| 久久国产精品无| 99久久综合狠狠综合久久| 日韩精品久久久肉伦网站| 亚洲精品久久久www| 99久久精品免费看国产免费| 精品久久久噜噜噜久久久| 精品久久久无码21p发布| 无码精品久久一区二区三区| 大蕉久久伊人中文字幕| 精品国产91久久久久久久| 人妻精品久久无码区| 久久人与动人物a级毛片| 欧美一级久久久久久久大| 大美女久久久久久j久久| 日本精品久久久久中文字幕| 99麻豆久久久国产精品免费| 久久丫精品国产亚洲av不卡| 日韩人妻无码精品久久久不卡| 无码AV中文字幕久久专区| 一本久久a久久精品vr综合| 婷婷久久香蕉五月综合加勒比| 亚洲精品乱码久久久久久久久久久久|