cari
Rumahpembangunan bahagian belakangGolangBagaimana untuk Menangkap dan Mencetak Output Masa Nyata daripada Ralat Standard Perintah Shell di Golang?

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

Cara Mendapatkan Keluaran Masa Nyata dan Mencetak Maklumat Diproses daripada Perintah Shell di Golang

Dalam panduan ini, kami akan menumpukan pada satu senario di mana kami melaksanakan perintah shell yang menghasilkan output dalam masa nyata, seperti ffmpeg. Kami berhasrat untuk mendapatkan semula output ini secara berterusan dan mencetak maklumat yang diproses berdasarkan data yang diberikannya.

Mari kita pecahkan kod asal dan jelaskan isu ini:

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) {
    // ...
}

Isunya terletak pada andaian output akan dihantar ke stdout, tetapi sebenarnya, ffmpeg menghantar mesej diagnostik kepada stderr sebaliknya. Untuk menangkap output yang dikehendaki, kita perlu menyalurkan aliran stderr. Berikut ialah kod yang disemak yang menangani perkara ini:

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()
}

Kini, kod dibaca daripada paip stderr dan mencetak perkataan yang diterimanya. Ini memastikan bahawa kami menangkap dan memaparkan mesej diagnostik yang dijana oleh ffmpeg.

Sebagai contoh, jika bar kemajuan ffmpeg kelihatan seperti ini:

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/

Kod kami akan menangkap dan mencetak perkataan ini sebaris baris:

frame=
101
fps=
0.0
q=
28.0
size=
91kB
time=
00:00:04.13
bitrate=
181.2kbits/
... (and so on)

Anda kemudian boleh menggunakan perkataan ini untuk menghuraikan maklumat yang berkaitan dan mengemas kini kemajuan anda sewajarnya.

Atas ialah kandungan terperinci Bagaimana untuk Menangkap dan Mencetak Output Masa Nyata daripada Ralat Standard Perintah Shell di Golang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Kod ujian yang bergantung pada fungsi init di GOKod ujian yang bergantung pada fungsi init di GOMay 03, 2025 am 12:20 AM

WhentestingGocodewithinitfunctions,useexplicitsetupfunctionsorseparatetestfilestoavoiddependencyoninitfunctionsideeffects.1)Useexplicitsetupfunctionstocontrolglobalvariableinitialization.2)Createseparatetestfilestobypassinitfunctionsandsetupthetesten

Membandingkan pendekatan pengendalian ralat Go ke bahasa lainMembandingkan pendekatan pengendalian ralat Go ke bahasa lainMay 03, 2025 am 12:20 AM

Go'SerrorHandlingReturnSerrorsArvalues, tidak seperti yang tidak seperti ini) go'SmethodensurexplIciterRorHandling, promMORPORUSustCodeBUtinceangeRningSniSik

Amalan terbaik untuk mereka bentuk antara muka yang berkesan di GOAmalan terbaik untuk mereka bentuk antara muka yang berkesan di GOMay 03, 2025 am 12:18 AM

AneffectiveInterfaceingoisminimal, clear, andpromotesloosecoupling.1) minimizetheinterforflexabilityandeaseofimplementation.2) userInterfacesforabstractionToSwapImplementationswithoutchangingcallingcode.3) Rekabentuk DesignForTabilitybyPrementeMaceStomockDePdePode.3) Rekabentuk

Strategi pengendalian ralat terpusat di manaStrategi pengendalian ralat terpusat di manaMay 03, 2025 am 12:17 AM

Pengendalian ralat berpusat boleh meningkatkan kebolehbacaan dan mengekalkan kod dalam bahasa Go. Kaedah dan kelebihan pelaksanaannya termasuk: 1. 2. Memastikan konsistensi pengendalian kesilapan dengan pengendalian berpusat. 3. Gunakan menangguhkan dan pulih untuk menangkap dan memproses panik untuk meningkatkan ketahanan program.

Alternatif untuk fungsi init untuk permulaan pakej di GOAlternatif untuk fungsi init untuk permulaan pakej di GOMay 03, 2025 am 12:17 AM

Ingo, alternativestoinitfunctionsincludecustominitialializationFunctionsandsingletons.1) custominitializationFunctionsAllowExplicitControloverwhenitializationoccurs, Constfordelayedorconditionalsetups.2) singletonsensenoneone-timeinitialializationcurncurncurmentasi

Taipkan pernyataan dan jenis suis dengan antara mukaTaipkan pernyataan dan jenis suis dengan antara mukaMay 02, 2025 am 12:20 AM

Gohandlesinterfacesandtypeassertionsefectively, enhancingcodeflexabilityandrobustness.1) snossersertionsallowruntimetypechecking, asseenwiththeshaphapeinterfaceandcircletype.2) typeWitchhandLemultipypeseficeMemently, gunaurvariousshapePhipeMemently, gunaurvariousshapePhipeMemently, gunaurvariousshapePhipeMemently, bermanfaat untuk

Menggunakan ralat.is dan ralat.as untuk pemeriksaan ralat di GOMenggunakan ralat.is dan ralat.as untuk pemeriksaan ralat di GOMay 02, 2025 am 12:11 AM

GO pengendalian kesilapan bahasa menjadi lebih fleksibel dan boleh dibaca melalui kesilapan dan kesilapan.as fungsi. 1.errors.is digunakan untuk memeriksa sama ada ralat adalah sama dengan ralat yang ditentukan dan sesuai untuk pemprosesan rantaian ralat. 2.Errors.as bukan sahaja boleh menyemak jenis ralat, tetapi juga menukar ralat kepada jenis tertentu, yang mudah untuk mengekstrak maklumat ralat. Menggunakan fungsi ini dapat memudahkan logik pengendalian ralat, tetapi perhatikan penyampaian rantaian ralat yang betul dan mengelakkan kebergantungan yang berlebihan untuk mencegah kerumitan kod.

Penalaan Prestasi Di GO: Mengoptimumkan Aplikasi AndaPenalaan Prestasi Di GO: Mengoptimumkan Aplikasi AndaMay 02, 2025 am 12:06 AM

Tomakeoapplicationsrunfasterandmoreeficiently, useprofilingtools, leverageconcurrency, andmanagememoryeffectively.1) usepprofforcpuandmemoryprofiloidentificybottlenecks.2)

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft