Não é possível analisar o valor da opção “-1” como formato de pixel ao transcodificar mp4 para mp4 usando ffmpeg

1

Eu estava tentando depurar um problema no qual meu arquivo mp4 não faz o upload para o youtube (com o erro "Falha no envio: não é possível processar o arquivo"). O vídeo é reproduzido normalmente no vlc player e pode ser carregado no Vegas Pro (na verdade, renderizá-lo novamente irá corrigir o problema de upload). A verificação de metadados usando o MediaInfo não mostra nada anormal comparado a outros arquivos mp4 da mesma fonte (e funcionou bem ao carregar para o youtube). Depois de algumas pesquisas com várias ferramentas, encontrei um problema quando segui as instruções do superusuário para transcodificar o arquivo mp4 original usando o ffmpeg. Como esse é o único problema que posso encontrar com o arquivo mp4 original, acho que pode ser a causa da falha no upload. Agora quero consertar isso.

O comando que usei é ffmpeg -i scripts/1.mp4 -pix_fmt yuv420p -crf 18 scripts/good.mp4

A saída é

ffmpeg -i scripts/1.mp4 -pix_fmt yuv420p -crf 18 scripts/good.mp4
ffmpeg version N-83577-g7e538c9 Copyright (c) 2000-2017 the FFmpeg developers
  built with gcc 4.8 (Ubuntu 4.8.4-2ubuntu1~14.04.3)
  configuration: --prefix=/home/________/ffmpeg_build --pkg-config-flags=--static --extra-cflags=-I/home/tianyig/ffmpeg_build/include --extra-ldflags=-L/home/tianyig/ffmpeg_build/lib --bindir=/home/tianyig/bin --enable-gpl --enable-libass --enable-libfdk-aac --enable-libfreetype --enable-libmp3lame --enable-libopus --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libx264 --enable-libx265 --enable-nonfree
  libavutil      55. 47.100 / 55. 47.100
  libavcodec     57. 80.101 / 57. 80.101
  libavformat    57. 66.102 / 57. 66.102
  libavdevice    57.  2.100 / 57.  2.100
  libavfilter     6. 73.100 /  6. 73.100
  libswscale      4.  3.101 /  4.  3.101
  libswresample   2.  4.100 /  2.  4.100
  libpostproc    54.  2.100 / 54.  2.100
[mov,mp4,m4a,3gp,3g2,mj2 @ 0x25074a0] Could not find codec parameters for stream 0 (Video: h264 (avc1 / 0x31637661), none, 540x960, 950 kb/s): unspecified pixel format
Consider increasing the value for the 'analyzeduration' and 'probesize' options
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'scripts/1.mp4':
  Metadata:
    major_brand     : isom
    minor_version   : 512
    compatible_brands: isomiso2avc1mp41
    encoder         : Lavf56.25.101
    copyright       : @Baidu.com
  Duration: 00:12:15.90, start: 0.089000, bitrate: 1027 kb/s
    Stream #0:0(und): Video: h264 (avc1 / 0x31637661), none, 540x960, 950 kb/s, 22.58 fps, 25 tbr, 16k tbn, 32k tbc (default)
    Metadata:
      handler_name    : VideoHandler
    Stream #0:1(und): Audio: aac (LC) (mp4a / 0x6134706D), 44100 Hz, stereo, fltp, 77 kb/s (default)
    Metadata:
      handler_name    : SoundHandler
[buffer @ 0x250e200] Unable to parse option value "-1" as pixel format
    Last message repeated 1 times
[buffer @ 0x250e200] Error setting option pix_fmt to value -1.
[graph 0 input from stream 0:0 @ 0x262a4e0] Error applying options to the filter.
Error opening filters!

Ele está reclamando sobre pix_fmt com valor -1, mas claramente eu já tenho um -pix_fmt yuv420p como parte do comando que não parece ser respeitado.

Alguma ideia de como consertar isso?

    
por punpun_G 22.02.2017 / 01:43

0 respostas