本文介绍的是Golang使用 os/exec 来执行 Linux 命令,分享出来供大家参考学习,下面来看看详细的介绍:
成都创新互联是专业的义乌网站建设公司,义乌接单;提供成都做网站、成都网站设计,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行义乌网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
下面是一个简单的示例:
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:%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 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:%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" 时,一直以为可以直接将 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 类型的返回值。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对创新互联的支持。