Go语言中提供了os/exec包来运行shell命令,os/exec包的Command()函数可以用于输入Shell命令,主要传入程序命令行和参数,第一个参数是命令行,第二个参数是命令行的参数,返回一个*Cmd的结构体,此结构体代表了一个执行的外部命令,当调用它的Run()、Output()、CombinedOutput()等方法后,这个命令就不能再次重复使用了,相当于是次抛。
示例:
cmd := exec.Command("ls","-l")
err := cmdRun()
执行完这个命令后,发现终端并没有任何输出,但实际这个命令已经执行了,只不过没有对输出进行捕获和处理输出,所以在终端看不到任何的输出。
解决方法:可以通过设置Stdin、Stdout、Stderr来处理标准输入输出,例如如果将Stdout设置为空,则会输出到null device中;如果Stdout设置为*os.File,则会将输出到文件中;如果Stdout设置为os.Stdout,则会输出到命令行中。
示例:
package main
import (
"fmt"
"os"
"os/exec"
)
func main() {
cmd := exec.Command("ls", "-l")
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
err := cmd.Run()
if err != nil {
fmt.Errorf("failed to run cmd:%v", err)
}
}
再举一个通过输入流到命令中,得到输出的例子:tr a-z A-z是将输入缓冲区汇总的小写转为大写
package main
import (
"fmt"
"os"
"os/exec"
"strings"
)
func main() {
cmd := exec.Command("tr", "a-z", "A-Z")
cmd.Stdin = strings.NewReader("i love aileen")
cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr
err := cmd.Run()
if err != nil {
fmt.Errorf("failed to run cmd:%v", err)
}
}
输出:
I LOVE AILEEN