go package学习——os/exec

壬癸甲乙 · · 9887 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

package exec用于运行外部命令,它封装了os.StartProcess,从而使操作更容易。

Index 

Examples 

Package Files 

exec.go lp_unix.go

1. 基本函数

func LookPath

func LookPath(file string) (string, error)
LookPath根据所给的二进制文件名file在PATH环境变量中寻找此二进制文件所在的路径信息:

path, err := exec.LookPath("fortune")
if err != nil {
    log.Fatal("installing fortune is in your future")
}
fmt.Printf("fortune is available at %s\n", path)
2. type Cmd

type Cmd struct {
    
    Path string

    Args []string

    Dir string

    Stdin io.Reader

    Stdout io.Writer
    Stderr io.Writer

    ExtraFiles []*os.File

    SysProcAttr *syscall.SysProcAttr

    Process *os.Process

    ProcessState *os.ProcessState
}
Cmd代表一个外部命令,此外部命令已准备好或已经在run。

func Command

func Command(name string, arg ...string) *Cmd
Command返回用于执行name代表的命令的Cmd结构,Cmd中设置了Path和Args,其它fields都为空。例子如下:

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())

func (*Cmd) CombinedOutput

func (c *Cmd) CombinedOutput() ([]byte, error)
运行命令c,并返回combined output和error。

func (*Cmd) Output

func (c *Cmd) Output() ([]byte, error)
运行命令c,并返回标准输出,例子如下:

out, err := exec.Command("date").Output()
if err != nil {
    log.Fatal(err)
}
fmt.Printf("The date is %s\n", out)

func (*Cmd) Run

func (c *Cmd) Run() error
Run运行指定的命令c,并等待其完成。

func (*Cmd) Start

func (c *Cmd) Start() error
Start也运行一个指定的命令c,但不等待其完成。例子如下:

cmd := exec.Command("sleep", "5")
err := cmd.Start()
if err != nil {
    log.Fatal(err)
}
log.Printf("Waiting for command to finish...")
err = cmd.Wait()
log.Printf("Command finished with error: %v", err)

func (*Cmd) Wait

func (c *Cmd) Wait() error
Wait等待命令c退出,命令c必须是由Start方法运行的。会阻塞在那里?


有疑问加站长微信联系(非本文作者)

本文来自:开源中国博客

感谢作者:壬癸甲乙

查看原文:go package学习——os/exec

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

9887 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传