>백엔드 개발 >Golang >Golang에서 쉘 명령의 표준 오류로부터 실시간 출력을 캡처하고 인쇄하는 방법은 무엇입니까?

Golang에서 쉘 명령의 표준 오류로부터 실시간 출력을 캡처하고 인쇄하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-10 03:03:09424검색

How to Capture and Print Realtime Output from a Shell Command's Standard Error in Golang?

Golang의 쉘 명령에서 실시간 출력을 검색하고 처리된 정보를 인쇄하는 방법

이 가이드에서는 특정 내용에 중점을 둘 것입니다. 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에서 쉘 명령의 표준 오류로부터 실시간 출력을 캡처하고 인쇄하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.