利用Golang如何调用Linux命令详解
发布时间:2020-12-16 19:07:58 所属栏目:大数据 来源:网络整理
导读:本文介绍的是Golang使用 os/exec 来执行 Linux 命令,分享出来供大家参考学习,下面来看看详细的介绍: 下面是一个简单的示例: package main import ( "fmt" "io/ioutil" "os/exec" ) func main() { cmd := exec.Command("/bin/bash","-c",`df -lh`) //创建
本文介绍的是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",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 } } 输出结果: 在写这句 # command-line-arguments ./exec_command.go:36: cannot convert err (type error) to type string 于是查了下才明白,error 类型本身是一个预定义好的接口,里面定义了一个method: type error interface { Error() string } 所以 总结 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程小技巧的支持。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |