如何从 Golang 中的 Shell 命令检索实时输出并打印处理后的信息
在本指南中,我们将重点关注特定的我们执行实时产生输出的 shell 命令的场景,例如 ffmpeg。我们的目标是稳定地检索此输出,并根据它提供的数据打印处理后的信息。
让我们分解原始代码并解释问题:
package main import ( "bufio" "fmt" "io" "os" "os/exec" "strings" ) func main() { // ... stdout, _ := cmd.StdoutPipe() cmd.Start() go print(stdout) cmd.Wait() } func print(stdout io.ReadCloser) { // ... }
问题在于假设输出将发送到 stdout,但实际上,ffmpeg 会将诊断消息发送到 stderr。为了捕获所需的输出,我们需要通过管道传输 stderr 流。下面是解决此问题的修订后的代码:
func main() { // ... stderr, _ := cmd.StderrPipe() cmd.Start() scanner := bufio.NewScanner(stderr) scanner.Split(bufio.ScanWords) for scanner.Scan() { m := scanner.Text() fmt.Println(m) } cmd.Wait() }
现在,代码从 stderr 管道读取并打印它接收到的单词。这确保我们捕获并显示 ffmpeg 生成的诊断消息。
例如,如果 ffmpeg 的进度条如下所示:
frame= 101 fps=0.0 q=28.0 size= 91kB time=00:00:04.13 bitrate= 181.2kbits/ frame= 169 fps=168 q=28.0 size= 227kB time=00:00:06.82 bitrate= 272.6kbits/ frame= 231 fps=153 q=28.0 size= 348kB time=00:00:09.31 bitrate= 306.3kbits/ frame= 282 fps=140 q=28.0 size= 499kB time=00:00:11.33 bitrate= 360.8kbits/
我们的代码将逐行捕获并打印这些单词line:
frame= 101 fps= 0.0 q= 28.0 size= 91kB time= 00:00:04.13 bitrate= 181.2kbits/ ... (and so on)
然后您可以使用这些单词来解析相关信息并相应地更新您的进度。
以上是如何在 Golang 中捕获并打印 Shell 命令标准错误的实时输出?的详细内容。更多信息请关注PHP中文网其他相关文章!