Não é possível parar o ffmpeg de gerar estatísticas

0

Estou escrevendo um script bash para acelerar podcasts. Nele, tenho:

ffmpeg -nostats -hide_banner -loglevel panic -y -i normal/$channel/$filename -filter:a "atempo=1.3" fast/$channel/$filename

No entanto, quando executo isso, recebo muita saída como esta:

stream #0:
   keyframe=1
   duration=0.026
   dts=336.196  pts=336.196
   size=836

A -nostatsbandeira não deveria parar com isso? De acordo com a documentação :

-stats(global)

Programe / estatísticas da codificação de impressão. Está ativado por padrão. Para desabilitá-lo explicitamente, é necessário especificar -nostats.

Além disso, ainda recebo a saída do banner do ffmpeg, mesmo tendo -hide_banner.

-hide_banner

Suprimir a impressão da faixa.

Todas as ferramentas do FFmpeg normalmente exibem um aviso de direitos autorais, opções de compilação e versões da biblioteca. Esta opção pode ser usada para suprimir a impressão dessas informações.

Não consigo entender por que o ffmpeg está ignorando essas sinalizações ou (mais provavelmente) o que estou fazendo de errado.

Atualizar

Eu também tentei -loglevel panice ainda gera tudo.

Também estou recebendo saída em vermelho assim:

00000060  b3 2e 0d 77 68 54 73 a9 e3 79 c7 65 ca 85 45 64 ...whTs..y.e..Ed
00000070  30 5c 94 ef 4b 02 be 67 4e 71 e4 39 18 5c 23 a3 0\..K..gNq.9.\#.
00000080  d6 54 ec 8a 79 59 e1 74 31 52 a4 5f 52 2f 48 5f .T..yY.t1R._R/H_
00000090  15 2a a5 5f 2f e7 c2 c3 7a 85 da bf 2e 18 ca d2 .*._/...z.......
000000a0  8d ad ab 69 d3 e8 c5 7c 98 7c 8c 79 34 c6 9a 2d ...i...|.|.y4..-
000000b0  10 fe 69 91 73 23 9e 3c 7e fc b3 eb e4 95 7c 92 ..i.s#.<~.....|.
000000c0  b4 b4 21 bc b4 5e 68 43 d7 fb 4b 4a 1a be 87 b4 ..!..^hC..KJ....
000000d0  f5 e0 e0 01 00 1f e4 40 33 bd ff fc 59 ae 86 94 .......@3...Y...
000000e0  30 60 30 f6 7f c1 12 4b c8 43 c9 2c a4 74 bc 3c 0`0....K.C.,.t.<
000000f0  f0 40 00 1d ab f1 9f 8c 9a 60 30 8c 6c c8 40 d5 .@.......`0.l.@.

Eu tenho mais saída em Pastebin

eu estou correndo ffmpeg version 3.0.2-1~trusty

Caleb Eby
fonte
superuser.com/questions/326629/… pode ser útil
rogerdpack 30/05
Qual é o comando e saída completos?
Gyan
Adicionado comando completo
Caleb Eby 31/05
Adicionado mais saída no Pastebin
Caleb Eby
se você não precisar de nenhuma saída, basta canalizá-la para / dev / null; i..effmpeg -nostats -hide_banner -loglevel panic -y -i normal/$channel/$filename -filter:a "atempo=1.3" fast/$channel/$filename >/dev/null 2>&1
Argonauts

Respostas:

1

A única bandeira que você precisa é:

-loglevel 0

Isso deve suprimir toda a saída do terminal. Se não estiver funcionando, verifique se está usando a versão mais recente do FFmpeg (4.0 no momento da redação).

sobutterysosmooth
fonte
1

Desculpas pela solução de necroposting; esse é o único thread existente que descreve a situação que estou enfrentando, que surgiu quando eu estava tentando solucionar erros posteriores em um script.

Uma maneira pela qual essa saída é acionada é que ela ffmpegpode estar consumindo bytes de stdin.

O seguinte fará com que a stream #0saída seja impressa; também fará com que os arquivos subsequentes falhem na conversão.

find . -name '*.ogg' | while read filename; do
    ffmpeg -loglevel 0 -nostats -i "$filename" "$filename.mp3"
done

O problema é devido ao uso do ffmpeg stdinpor padrão; use -nostdinpara desligar esse comportamento

Na página do manual:

-stdin
    Enable interaction on standard input. On by default unless standard input is
    used as an input. To explicitly disable interaction you need to specify
    "-nostdin".

    Disabling interaction on standard input is useful, for example, if ffmpeg is
    in the background process group. Roughly the same result can be achieved with
    "ffmpeg ... < /dev/null" but it
    requires a shell.
taifwa
fonte