Как получить вывод команды - PullRequest
0 голосов
/ 08 ноября 2019

Я вызываю скрипт Python из кода Go:

package main
import (
    "os/exec"
    "os"
    "fmt"
    "time"
    "encoding/json"
)

func main() {
    cmd := exec.Command("python","/home/devendra/Desktop/sync/blur_multithread.py","http://4.imimg.com/data4/TP/ED/NSDMERP-28759633/audiovideojocks.png")
    var logs=make(map[string]interface{})
    logs["tes"]=os.Stdout
    _ = cmd.Run()   
    WriteLogs(logs)//Writelog is my function which logs everything in a file
}

func WriteLogs(logs map[string]interface{}){
  currentTime := time.Now().Local()
  jsonLog, err := json.Marshal(logs)
  if err != nil {
    fmt.Println(err.Error())
  }

  jsonLogString := string(jsonLog[:len(jsonLog)])
  logfile := "/home/devendra/ImageServiceLogs/"+ "ImageServiceLogs_" + currentTime.Format("2006-01-02") + ".txt"
  if logfile == "" {
    fmt.Println("Could not find logfile in configuration ...!!!")
  } else {

    jsonLogFile, err := os.OpenFile(logfile, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0644)
    defer jsonLogFile.Close()
    if err != nil {
      fmt.Println(err.Error())
    }

    jsonLogFile.WriteString(jsonLogString + "\n")
  }
}

Но в журналах значение поля tes равно нулю, в то время как мой скрипт python выдает мне вывод. Как получить вывод скрипта Python в моем коде?

1 Ответ

2 голосов
/ 08 ноября 2019

В соответствии с примерами официальной документации, exec.Cmd.Ouput() ([]byte, error) даст вам выход команды после ее завершения.

https://golang.org/pkg/os/exec/#Cmd.Output

package main

import (
    "fmt"
    "log"
    "os/exec"
)

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

Для получения как stdout, так и stderrпроцесса, писатель должен использовать exec.Cmd.CombinedOutput https://golang.org/pkg/os/exec/#Cmd.CombinedOutput

Если кто-то хочет получить вывод команды в режиме реального времени на свой терминал, то писатель должен установить свойства exec.Cmd.Stdout и exec.Cmd.Stderr соответственно, os.Stdout и os.Stderr и вызовите метод exec.Cmd.Run() error.

https://golang.org/pkg/os/exec/#Cmd https://golang.org/pkg/os/exec/#Cmd.Run

package main

import (
    "fmt"
    "log"
    "os"
    "os/exec"
)

func main() {
    cmd := exec.Command("date")
    cmd.Stdout = os.Stdout
    cmd.Stderr = os.Stderr
    err := cmd.Run()
    if err != nil {
        log.Fatal(err)
    }
    fmt.Printf("The date is %s\n", out)
}

Для переадресации выходов и одновременной записи ихАвтор должен обратиться за помощью к пакету io, чтобы использовать io.MultiWriter

https://golang.org/pkg/io/#MultiWriter

package main

import (
    "fmt"
    "io"
    "log"
    "os"
    "os/exec"
)

func main() {
    stdout := new(bytes.Bufer)
    stderr := new(bytes.Bufer)
    cmd := exec.Command("date")
    cmd.Stdout = io.MultiWriter(os.Stdout, stdout)
    cmd.Stderr = io.MultiWriter(os.Stderr, stderr)
    err := cmd.Run()
    if err != nil {
        log.Fatal(err)
    }
    fmt.Printf("The date is %s\n", out)
}

В качестве альтернативы, вы можете использовать exec.Cmd.{Stdout,Stderr}Pipe(), см. официальную документациюпримеры https://golang.org/pkg/os/exec/#Cmd.StdoutPipe

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...