本文介绍的是Golang使用 os/exec 来执行 Linux 命令,分享出来供大家参考学习,下面来看看详细的介绍:
下面是一个简单的示例:
| 代码如下 | 复制代码 |
package main
import ( "fmt" "io/ioutil" "os/exec" )
func main() { cmd := exec.Command("/bin/bash", "-c", `df -lh`)
//创建获取命令输出管道 stdout, err := cmd.StdoutPipe() if err != nil { fmt.Printf("Error:can not obtain stdout pipe for command:%sn", err) return }
//执行命令 if err := cmd.Start(); err != nil { fmt.Println("Error:The command is err,", err) return }
//读取所有输出 bytes, err := ioutil.ReadAll(stdout) if err != nil { fmt.Println("ReadAll Stdout:", err.Error()) return }
if err := cmd.Wait(); err != nil { fmt.Println("wait:", err.Error()) return } fmt.Printf("stdout:nn %s", bytes) } | |
或者创建一个缓冲读取器按行读取:
| 代码如下 | 复制代码 |
package main
import ( "bufio" "fmt" "os/exec" )
func main() { cmd := exec.Command("/bin/bash", "-c", `df -lh`)
//创建获取命令输出管道 stdout, err := cmd.StdoutPipe() if err != nil { fmt.Printf("Error:can not obtain stdout pipe for command:%sn", err) return }
//执行命令 if err := cmd.Start(); err != nil { fmt.Println("Error:The command is err,", err) return }
//使用带缓冲的读取器 outputBuf := bufio.NewReader(stdout)
for {
//一次获取一行,_ 获取当前行是否被读完 output, _, err := outputBuf.ReadLine() if err != nil {
// 判断是否到文件的结尾了否则出错 if err.Error() != "EOF" { fmt.Printf("Error :%sn", err) } return } fmt.Printf("%sn", string(output)) }
//wait 方法会一直阻塞到其所属的命令完全运行结束为止 if err := cmd.Wait(); err != nil { fmt.Println("wait:", err.Error()) return } } | |
输出结果:
在写这句if err.Error() != "EOF"时,一直以为可以直接将 error 类型直接转为 string 然后就可以比较了,所以刚开始写的代码是这样的if string(err) != "EOF",但是一直报下面这个错误:
# command-line-arguments
./exec_command.go:36: cannot convert err (type error) to type string
于是查了下才明白,error 类型本身是一个预定义好的接口,里面定义了一个method:
type error interface {
Error() string
}
所以err.Error()才是一个 string 类型的返回值。
孢子2生物进化中文版(Spores)
孢子2生物进化中文版让我们来做一回疯狂的博士,打造一个属于自
叫我万岁爷九游官方版
叫我万岁爷带你体验当换地点感觉,全新的模拟手游大作让你开始一
梦回凤歌
梦回凤歌手游中你将步入古代的宫廷纷争之中,本想度过美好幸福的
洋果子店rose最新版本
洋果子店最新版是一款十分容易让人垂涎的开店经营类手游。游戏玩
明日大亨最新版
明日大亨手游,一个非常经典有趣的模拟经营类型的商战手游,在游