大佬教程收集整理的这篇文章主要介绍了golang中os/exec包用法,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
exec包执行外部命令,它将os.StartProcess进行包装使得它更容易映射到stdin和stdout,并且利用pipe连接I/O.
func LookPath(file String) (String,error) //LookPath在环境变量中查找科执行二进制文件,如果file中包含一个斜杠,则直接根据绝对路径或者相对本目录的相对路径去查找
func main() { f,err := exec.LookPath("ls") if err != nil { fmt.Println(err) } fmt.Println(f) // /bin/ls }
type Cmd struct { Path String //运行命令的路径,绝对路径或者相对路径 Args []String // 命令参数 Env []String //进程环境,如果环境为空,则使用当前进程的环境 Dir String //指定command的工作目录,如果dir为空,则comman在调用进程所在当前目录中运行 Stdin io.Reader //标准输入,如果stdin是nil的话,进程从null device中读取(os.DevNull),stdin也可以时一个文件,否则的话则在运行过程中再开一个goroutIne去 //读取标准输入 Stdout io.Writer //标准输出 Stderr io.Writer //错误输出,如果这两个(Stdout和Stderr)为空的话,则command运行时将响应的文件描述符连接到os.DevNull ExtraFiles []*os.File SysProcAttr *syscall.SysProcAttr Process *os.process //Process是底层进程,只启动一次 ProcessState *os.processState //ProcessState包含一个退出进程的信息,当进程调用Wait或者Run时便会产生该信息. }
func Command(name String,arg ...String) *Cmd //command返回cmd结构来执行带有相关参数的命令,它仅仅设定cmd结构中的Path和Args参数,如果name参数中不包含路径分隔符,command使用LookPath来解决路径问题,否则的话就直接使用Name;Args直接跟在command命令之后,所以在Args中不许要添加命令.
func main() { cmd := exec.Command("tr","a-z","A-Z") cmd.Stdin = Strings.NewReader("some input") var out bytes.buffer cmd.Stdout = &out err := cmd.Run() if err != nil { log.Fatal(err) } fmt.Printf("in all caps: %q\n",out.String()) //in all caps: "SOME INPUT" }
func (c *Cmd) CombinedOutput() ([]byte,error) //运行命令,并返回标准输出和标准错误
func main() { cmd := exec.Command("ls") //查看当前目录下文件 out,err := cmd.CombinedOutput() if err != nil { fmt.Println(err) } fmt.Println(String(out)) }
func main() { cmd := exec.Command("ls") ///查看当前目录下文件 out,err := cmd.output() if err != nil { fmt.Println(err) } fmt.Println(String(out)) }注意:Output()和CombinedOutput()不能够同时使用,因为command的标准输出只能有一个,同时使用的话便会定义了两个,便会报错
func main() { cmd := exec.Command("ls") cmd.Stdout = os.Stdout // cmd.Run() fmt.Println(cmd.Start()) //exec: already started }注:一个command只能使用Start()或者Run()中的一个启动命令,不能两个同时使用.
package main import ( "fmt" "os" "os/exec" ) func main() { cmd := exec.Command("cat") stdin,err := cmd.StdinPipe() if err != nil { fmt.Println(err) } _,err = stdin.Write([]byte("tmp.txt")) if err != nil { fmt.Println(err) } stdin.Close() cmd.Stdout = os.Stdout //终端标准输出tmp.txt cmd.Start() }
func main() { cmd := exec.Command("ls") stdout,err := cmd.StdoutPipe() //指向cmd命令的stdout cmd.Start() content,err := IoUtil.ReadAll(stdout) if err != nil { fmt.Println(err) } fmt.Println(String(content)) //输出ls命令查看到的内容 }
type Error //Error返回科执行二进制文件名字不能够执行的原因的错误
type Error struct { Name String Err error }
func (e *Error) Error() String
type ExitError //一个command不能够正常退出的error
type ExitError struct { *os.processState }
func (e *ExitError) Error() String
实践
同步
lsCmd := exec.Command("bash","-c","/home/sHell/modifyhls.sh /data/chAnnellist/chAnnel03/index.m3u8 10 a a ")
lsOut,err := lsCmd.output()
if err != nil {
panic(err)
}
fmt.Println("> ls -a -l -h")
fmt.Println(String(lsOut))
异步
lsCmd := exec.Command("bash","/home/sHell/modifyhls.sh /data/chAnnellist/chAnnel03/index.m3u8 10 a a & ")
err := lsCmd.Start()
if err != nil {
panic(err)
}
写函数
func exec_sHell(s String) { lsCmd := exec.Command("bash","/home/sHell/modifyhls.sh /data/chAnnellist/chAnnel03/index.m3u8 10 a a & ") err := lsCmd.Start() if err != nil { panic(err) } }
以上是大佬教程为你收集整理的golang中os/exec包用法全部内容,希望文章能够帮你解决golang中os/exec包用法所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。