ホームページ >バックエンド開発 >Golang >Go で長時間実行されるシェル コマンドからリアルタイム出力を取得して処理するにはどうすればよいですか?

Go で長時間実行されるシェル コマンドからリアルタイム出力を取得して処理するにはどうすればよいですか?

DDD
DDDオリジナル
2024-12-30 09:44:09228ブラウズ

How Can I Retrieve and Process Real-time Output from Long-Running Shell Commands in Go?

シェル コマンドを使用したライブ出力取得

Go で os/exec を使用して長時間実行されるシェル コマンドを実行する場合、多くの場合、出力をリアルタイムで取得して処理すると有益です。 。たとえば、ffmpeg コマンドを考えてみましょう。このコマンドは、次のような行の形式で進行状況情報を出力します。

frame=  101 fps=0.0 q=28.0 size=      91kB time=00:00:04.13 bitrate= 181.2kbits/

私たちの目標は、これらの行をキャプチャして処理し、進行状況情報を抽出してライブ進行状況バーを表示することです。 .

解決策: 診断メッセージに stderr を使用する

stdout とは異なり、ffmpeg は診断メッセージ (コンソール出力) を標準エラー出力に出力します。代わりに stderr から読み取るようにコードを変更することで、進行状況情報をキャプチャできます。

package main

import (
    "bufio"
    "fmt"
    "os/exec"
    "strings"
)

func main() {
    args := "-i test.mp4 -acodec copy -vcodec copy -f flv rtmp://aaa/bbb"
    cmd := exec.Command("ffmpeg", strings.Split(args, " ")...)

    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 の場合、「時間」フィールドに興味があります:

time=00:00:04.13

この値を解析し、比率 (例: "4.13 秒 / 合計時間") に変換することで、次のことが可能になります。進捗状況をパーセンテージで表示します。これにより、コマンドの進行状況をリアルタイムで追跡し、ユーザーフレンドリーなエクスペリエンスを提供できるようになります。

以上がGo で長時間実行されるシェル コマンドからリアルタイム出力を取得して処理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。