Go で os/exec を使用して長時間実行されるシェル コマンドを実行する場合、多くの場合、出力をリアルタイムで取得して処理すると有益です。 。たとえば、ffmpeg コマンドを考えてみましょう。このコマンドは、次のような行の形式で進行状況情報を出力します。
frame= 101 fps=0.0 q=28.0 size= 91kB time=00:00:04.13 bitrate= 181.2kbits/
私たちの目標は、これらの行をキャプチャして処理し、進行状況情報を抽出してライブ進行状況バーを表示することです。 .
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 サイトの他の関連記事を参照してください。