前言
这里使用 os/exec 包,通过 exec.command 创建 cmd命令,最后通过 cmd.run 执行命令
简单使用
cmd.Output 可以在返回shell结果,是在其方法中设置了 Stdout = bytes.Buffer, Stderr = &prefixSuffixSaver{N: 32 << 10}
package main
import (
"log"
"os/exec"
)
func main() {
cmd := exec.Command("echo", "abc")
output, err := cmd.Output()
if err != nil {
log.Fatalf("cmd.ouput: %v", err)
}
println(string(output)) //abc
}
Stderr,Stdout,Stdin 区别
Stderr 和 Stdout 都是输出,但是 Stdout是标准输出,Stderr是错误输出,区别在意义上不一样
输出为 nil 则会 向 /dev/null(黑洞) 进行输出
下面代码不会输出内容,因为未设置输出
package main
import (
"log"
"os/exec"
)
func main() {
cmd := exec.Command("echo", "abc")
err := cmd.Run()
if err != nil {
log.Fatalf("cmd.ouput: %v", err)
}
}
下面的代码会向控制台进行输出
package main
import (
"log"
"os"
"os/exec"
)
func main() {
cmd := exec.Command("echo", "abc")
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
err := cmd.Run()
if err != nil {
log.Fatalf("cmd.ouput: %v", err)
}
}
下面的例子演示了通过 Stdin 进行输入 abc,通过 shell tr a-z A-Z 来进行小写转大写
package main
import (
"bytes"
"log"
"os"
"os/exec"
)
func main() {
cmd := exec.Command("tr", "a-z", "A-Z")
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
var data bytes.Buffer
data.Write([]byte("abc"))
cmd.Stdin = &data
err := cmd.Run()
if err != nil {
log.Fatalf("cmd.ouput: %v", err)
}
}
下面这图片是直接执行 tr a-z A-Z 等待输入的场景
cmd.string
该命令在调试时使用,用于输出真实执行的 shell命令
package main
import (
"os/exec"
)
func main() {
cmd := exec.Command("go", "-run", "main.go")
println(cmd.String()) //go -run main.go
}