zoukankan      html  css  js  c++  java
  • golang --- os/exec 执行外部命令

    实例1:

    package main
    
    import (
    	"bufio"
    	"fmt"
    	"os"
    	"os/exec"
    	//"strings"
    )
    
    func main() {
    	reader := bufio.NewReader(os.Stdin)
    	cmdString, err := reader.ReadString('
    ')
    	if err != nil {
    		fmt.Fprintln(os.Stderr, err)
    	}
    	fmt.Println(cmdString)
    
    	//cmdString = strings.TrimSuffix(cmdString, "
    ")
    	cmdString = cmdString[:len(cmdString)-2]
    	cmd := exec.Command(cmdString)
    	cmd.Stderr = os.Stderr
    	cmd.Stdout = os.Stdout
    	cmd.Run()
    }
    

     

    windows内置命令实例

    package main
    
    import (
    	"fmt"
    	"os/exec"
    )
    
    func main() {
    	c := exec.Command("cmd", "/C", "del", "D:\a.txt")
    	exec.Command()
    
    	if err := c.Run(); err != nil {
    		fmt.Println("Error: ", err)
    	}
    }
    

      

    golang os/exec 执行外部命令

     

    exec包执行外部命令,它将os.StartProcess进行包装使得它更容易映射到stdin和stdout,并且利用pipe连接i/o.

    func LookPath(file string) (string, error) //LookPath
    LookPath在环境变量中查找科执行二进制文件,如果file中包含一个斜杠,则直接根据绝对路径或者相对本目录的相对路径去查找
    package main
    
    import (
    	"fmt"
    	"os/exec"
    )
    
    func main() {
    	f, err := exec.LookPath("curl")
    	if err != nil {
    		fmt.Println(err)
    	}
    	fmt.Println(f) //  /bin/ls
    }
    

      输出:

    D:curlcurl.exe
    

      

    type Cmd   //表示一个正在准备或者正在运行的外部命令

    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中不需要添加命令.

    package main
    
    import (
    	"bytes"
    	"fmt"
    	"log"
    	"os/exec"
    	"strings"
    )
    
    func main() {
    	cmd := exec.Command("cmd.exe", "C", "dir")
    	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
    ", out.String())
    
    }
    

      func (c *Cmd) CombinedOutput() ([]byte, error) //运行命令,并返回标准输出和标准错误

    package main
    
    import (
    	"fmt"
    	"os/exec"
    )
    
    func main() {
    	cmd := exec.Command("cmd", "/C", "dir")
    	out, err := cmd.CombinedOutput()
    	if err != nil {
    		fmt.Println(err)
    	}
    	fmt.Println(string(out))
    
    }
    

      func (c *Cmd) Output() ([]byte, error)     //运行命令并返回其标准输出

    package main
    
    import (
    	"fmt"
    	"os/exec"
    )
    
    func main() {
    	cmd := exec.Command("cmd", "/C", "dir")
    	out, err := cmd.Output()
    	if err != nil {
    		fmt.Println(err)
    	}
    	fmt.Println(string(out))
    
    }
    

      注意:Output()和CombinedOutput()不能够同时使用,因为command的标准输出只能有一个,同时使用的话便会定义了两个,便会报错

    func (c *Cmd) Run() error          //开始指定命令并且等待他执行结束,如果命令能够成功执行完毕,则返回nil,否则的话边会产生错误
    func (c *Cmd) Start() error          //使某个命令开始执行,但是并不等到他执行结束,这点和Run命令有区别.然后使用Wait方法等待命令执行完毕并且释放响应的资源
    

      

    package main
    
    import (
    	"fmt"
    	"os/exec"
    )
    
    func main() {
    	cmd := exec.Command("cmd", "/C", "dir")
    	err := cmd.Run()
    	if err != nil {
    		fmt.Println(err)
    	}
    	fmt.Println(cmd.Start())
    
    }
    

      输出:

    exec: already started
    

      注:一个command只能使用Start()或者Run()中的一个启动命令,不能两个同时使用.

    func (c *Cmd) StderrPipe() (io.ReadCloser, error)  //StderrPipe返回一个pipe,这个管道连接到command的标准错误,当command命令退出时,Wait将关闭这些pipe
    func (c *Cmd) StdinPipe() (io.WriteCloser, error)   //StdinPipe返回一个连接到command标准输入的管道pipe
    

      

    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
    	cmd.Start()
    
    }
    

      

    func (c *Cmd) StdoutPipe() (io.ReadCloser, error)        //StdoutPipe返回一个连接到command标准输出的管道pipe
    

      

    package main
    
    import (
    	"fmt"
    	"io/ioutil"
    	"os/exec"
    	"time"
    )
    
    func main() {
    	cmd := exec.Command("dir")
    	stdout, err := cmd.StdoutPipe()
    	if err != nil {
    		fmt.Println(err)
    	}
    	cmd.Run()
    	go func() {
    		content, err := ioutil.ReadAll(stdout)
    		if err != nil {
    			fmt.Println("err: ", err)
    		}
    		fmt.Println(string(content))
    	}()
    	time.Sleep(1 * time.Second)
    	fmt.Println("main is ending")
    
    }
    

      


    func (c *Cmd) Wait() error //Wait等待command退出,他必须和Start一起使用,如果命令能够顺利执行完并顺利退出则返回nil,否则的话便会返回error,其中Wait会是放掉所有与cmd命令相关的资源

    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
    

      

     

  • 相关阅读:
    负载均衡
    二叉树反转
    hashMap 和红黑树
    linux c++ 服务器编程,收藏一个测试例子
    某某音乐盒面试
    Linux中的文件i节点
    linux 文件格式压缩
    类string的构造函数、拷贝构造函数和析构函数
    计算二叉树的深度
    string转换为decimal
  • 原文地址:https://www.cnblogs.com/saryli/p/11651946.html
Copyright © 2011-2022 走看看