• <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年1月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234


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

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 219191
            • 排名 - 117

            最新評論

            閱讀排行榜

            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 思月行云 閱讀(1207) 評論(0)  編輯 收藏 引用 所屬分類: Golang
            午夜欧美精品久久久久久久| 日韩AV无码久久一区二区 | 久久精品国产亚洲av瑜伽| 久久国产V一级毛多内射| 少妇人妻综合久久中文字幕| 久久国产乱子伦精品免费强| 性做久久久久久久久久久| 韩国三级大全久久网站| 久久久无码精品亚洲日韩蜜臀浪潮| 韩国三级大全久久网站| 亚洲AV日韩AV永久无码久久| 久久精品中文字幕第23页| 人妻少妇久久中文字幕一区二区 | 久久久久久午夜精品| 久久亚洲国产午夜精品理论片| 精品久久亚洲中文无码| 亚洲精品乱码久久久久久不卡| 欧美亚洲另类久久综合| 狠狠88综合久久久久综合网 | 精品一区二区久久| 久久99热只有频精品8| 亚洲综合伊人久久综合| 欧美激情精品久久久久久久| 99久久精品久久久久久清纯| 97精品伊人久久大香线蕉app| 久久久亚洲欧洲日产国码二区| 亚洲人成电影网站久久| 亚洲精品高清一二区久久| 久久久久国产精品三级网| 久久国产精品免费一区| 国产福利电影一区二区三区久久老子无码午夜伦不 | 午夜精品久久久久久影视riav| 9999国产精品欧美久久久久久| 国产精品99久久免费观看| 久久久精品人妻一区二区三区蜜桃 | 无码人妻精品一区二区三区久久久| 欧美成a人片免费看久久| 久久久久久久久久免免费精品 | 久久超碰97人人做人人爱| 亚洲国产精品无码久久98| 精品久久久久久亚洲精品 |