• <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
            <2018年10月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910


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

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 215352
            • 排名 - 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
            久久久久这里只有精品| 97久久久久人妻精品专区| 久久久久国色AV免费看图片| 久久青青草原精品国产软件| 久久精品免费全国观看国产| 人妻精品久久无码区| 国内精品久久久久久99| 久久亚洲中文字幕精品一区四| 人妻无码αv中文字幕久久琪琪布 人妻无码精品久久亚瑟影视 | 国产成人无码精品久久久久免费| 精品无码久久久久久久动漫| 精品国产乱码久久久久久呢| 久久国产免费观看精品| 2021国内精品久久久久久影院| 色综合合久久天天综合绕视看| 超级97碰碰碰碰久久久久最新| 国产欧美一区二区久久| 久久亚洲精品国产亚洲老地址| 伊人久久免费视频| 伊人色综合久久天天人手人婷 | 久久99国产综合精品| 三级韩国一区久久二区综合| 久久最近最新中文字幕大全 | 久久免费高清视频| 亚洲精品乱码久久久久久蜜桃图片| 一本一道久久精品综合| 国产精品美女久久久| 99久久国产宗和精品1上映| 热久久视久久精品18| 日批日出水久久亚洲精品tv| 久久99精品久久久久久齐齐| 久久国产精品久久精品国产| 国产精品天天影视久久综合网| 亚洲中文精品久久久久久不卡| 一本久久a久久精品综合香蕉| 国产成人精品久久综合| 2020最新久久久视精品爱| 日本福利片国产午夜久久| 伊人久久大香线焦综合四虎| 91久久精品无码一区二区毛片| 国产精品久久久久久福利漫画|