我就废话不多说了,大家还是直接看代码吧~
cmd := exec.Command('cmd') in := bytes.NewBuffer(nil) cmd.Stdin = in//绑定输入 var out bytes.Buffer cmd.Stdout = &out //绑定输出 go func() { in.WriteString('node E:/design/test.jsn')//写入你的命令,可以有多行,'n'表示回车 }() err = cmd.Start() if err != nil { log.Fatal(err) } log.Println(cmd.Args) err = cmd.Wait() if err != nil { log.Printf('Command finished with error: %v', err) } fmt.Println(out.String())
补充:golang 执行外部命令 超时处理 exec.CommandContext
使用exec.CommandContext来处理外部命令的超时
func main() { timeout := 5 ctx, cancel := context.WithTimeout(context.Background(), time.Duration(timeout+5)*time.Second) defer cancel() cmdarray := []string{'-c', fmt.Sprintf('%s %s', 'sleep', '10')} cmd := exec.CommandContext(ctx, 'bash', cmdarray...) out, err := cmd.CombinedOutput() //if ctx.Err() == context.DeadlineExceeded {} fmt.Printf('ctx.Err : [%v]n', ctx.Err()) fmt.Printf('error : [%v]n', err) fmt.Printf('out : [%s]n', string(out))}
运行结果是:
ctx.Err : [context deadline exceeded]error : [signal: killed]out : []
如果是一个命令错误输出是什么:
下面这个例子是使用sleep不带参数,显示是错误的。
cmdarray := []string{'-c', fmt.Sprintf('%s %s', 'sleep', '')}
ctx.Err : [<nil>]error : [exit status 1]out : [usage: sleep seconds]
可以命令的执行错误不会导致ctx.Err()错误。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持乐呵呵网。如有错误或未考虑完全的地方,望不吝赐教。