本文介绍的是Golang使用 os/exec 来执行 Linux 命令,分享出来供大家参考学习,下面来看看详细的介绍:

下面是一个简单的示例:

package mainimport ( "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:%s\n", 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:\n\n %s", bytes)}

或者创建一个缓冲读取器按行读取:

package mainimport ( "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:%s\n", 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 :%s\n", err)   }   return  }  fmt.Printf("%s\n", string(output)) } //wait 方法会一直阻塞到其所属的命令完全运行结束为止 if err := cmd.Wait(); err != nil {  fmt.Println("wait:", err.Error())  return }}

输出结果:

if err.Error() != "EOF"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() 

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。

原文链接:http://www.tianfeiyu.com/?p=2673