Multi
Última actualización
Última actualización
Toda la práctica la realizaremos en un servidor Ubuntu 22.0.
A continuación veremos dos herramientas que nos permitirán trabajar con archivos multimedia, son Ffmpeg y yt-dlp. Primero vamos a configurar el directorio de trabajo del servidor Ubuntu:
FFmpeg es una potente herramienta de línea de comandos y biblioteca de software diseñada para grabar, convertir y transmitir audio y video en una amplia variedad de formatos. Es conocido por su versatilidad y capacidad para manejar casi cualquier tarea relacionada con multimedia, desde la captura de pantalla hasta la transcodificación en tiempo real y la edición de video.
Más info .
La instalación de ffmpeg es tan sencilla como:
YT-DLP es un proyecto de software gratuito y de código abierto creado a partir de youtube-dlc, el popular descargador de YouTube, pero incluye características y mejoras adicionales. Esta herramienta se utiliza principalmente para descargar videos de YouTube, Vimeo y otros sitios web similares.
Al terminar deberás otorgar permisos de acceso:
Una vez instalada y funcionando, para hacer su función principal de descarga de video de YouTube.
Primero podemos asegurarnos del formato de descarga y el nombre:
Esto mostrará lo siguiente:
En videos más antiguos puedes ver la diferencia de formatos:
Ahora sí, vamos a descargar el video. Para ello, especifica la url del video a descargar, tenemos varias opciones:
Descargar y fusionar el mejor formato de solo video y el mejor formato de solo audio, o descargar el mejor formato combinado si el formato de solo video no está disponible:
Descargar el mejor formato de solo video y el mejor formato de solo audio por separado. Para este caso, se debe configurar la salida ya que, por defecto, el mejor video y el mejor audio tendrán el mismo nombre de archivo:
Descargar el mejor video (que también tenga audio), pero que no sea más grande de 50 MB, o el peor video (que también tenga audio) si no hay ningún video de menos de 50 MB:
Descargar el mejor video mp4 disponible o el mejor video si mp4 no está disponible.
Mediante el software FFprobe instalado con el paquete FFmpeg podemos revisar la información de un archivo multimedia.
El parámetro -i
indica la información general. El comando mostrará esto:
En las ultimas lineas se puede observar lo siguiente:
Si desglosamos esta información nos dice:
Stream #0:0
: Este es el primer stream del archivo multimedia. Es un stream de video (Video
) codificado con el códec VP9 (vp9
). Tiene un perfil específico (Profile 0
). La resolución del video es de 1920x1080 píxeles (1920x1080
). Utiliza el formato de color YUV420P con un espacio de color estándar (yuv420p(tv, bt709)
). Tiene una tasa de bits de 922 Kbps (922 kb/s
) y una velocidad de fotogramas de 25 fotogramas por segundo (25 fps
). El resto son parámetros de temporalización.
Stream #0:1
: Este es el segundo stream del archivo multimedia. Es un stream de audio (Audio
) y está codificado con el códec AAC (aac
). Tiene una frecuencia de muestreo de audio de 44100 Hz (44100 Hz
), en estéreo (stereo
) y con el formato de punto flotante (fltp
). Por último, tiene una tasa de bits de audio de 127 Kbps (127 kb/s
).
El propio ffmpeg ofrece la posibilidad de hacer esto:
En este caso reconvertimos el video con dos códecs diferentes:
Fijémonos sobre todo en el tamaño de ambos archivos:
En la siguiente práctica, usamos para el mismo video y tres codecs de audio diferentes, que son mp3, aac y vorbis:
La opción copy
en el codec de video obliga a ffmpeg a no hacer conversión de formatos de video, sino que utiliza el que ya tiene lo que ahorra tiempo.
Aquí nos encontramos con el mismo formato de archivo multimedia pero con el audio cambiado:
De nuevo, comparando archivos vemos:
Para esta práctica modificaremos parámetros de video y audio para reducir el tamaño de archivo con perdida a partir del bitrate.
Recuerda que la tasa de bits (bitrate) es una medida que indica la cantidad de datos que se transmite o se procesa en un segundo de audio o video ya que se mide en bits por segundo (bps) o kilobits por segundo (kbps) y determina la calidad multimedia.
Ejecutamos lo siguiente:
Estos parámetros habrán cambiado lo siguiente:
-b:v 2500k
: Establece la tasa de bits de video (-b:v
) en 2500 kilobits por segundo (2.5Mbps). Esto controla la calidad de video y el tamaño del archivo de salida. Cuanto mayor sea la tasa de bits, mejor será la calidad, pero también resultará en un archivo más grande.
-b:a 192k
: Establece la tasa de bits de audio (-b:a
) en 192 kilobits por segundo (0.2Mbps). Esto controla la calidad del audio y el tamaño del archivo de salida de audio.
Si recuerdas de más arriba, el video tenia tasa de bits de 922 Kbps
y el audio de 127 Kbps
. Por lo que hemos reducido su bitrate a más de la mitad con su consecuente perdida.
Por defecto, el comando cambiará el códec de vídeo a h264 por lo que si comparas tamaños de archivo te darás cuenta que ha aumentado el tamaño, para poder compararlo deberás configurar el códec original (en mi caso VP9
) con el siguiente comando:
Ahora sí podemos comparar:
A continuación pongo una tabla de referencia:
A veces nos puede interesar simplemente extraer los canales de audio de un video para poder fragmentarlo o añadirlo a otro video.
Para extraerlo a un archivo MP3, simplemente ejecuta:
FFmpeg detecta que el archivo de destino es un archivo de audio y hará la conversión automáticamente, ten en cuenta que:
-vn
Elimina el canal de video.
-an
Elimina el canal de audio.
Veamos como recortar un fragmento de tiempo de un video más largo. Digamos, obtener el fragmento de video desde los 35seg hasta los 65seg (30seg de duración).
Existe un parámetro con el que podemos realizar estas operaciones y dos formas de hacerlo:
Ambas darán el mismo resultado.
Con esto también podemos extraer el audio recortado por si nos interesa un fragmento especifico:
Fusionar fragmentos de video nos puede ayudar a crear composiciones simples para videos de presentación o de anuncio.
Para juntar dos fragmentos de video con FFmpeg usaremos el filtro concat
que nos permite concatenar varios archivos de video en uno solo. Vamos a recortar dos fragmentos y ver como:
Primero, crearemos un archivo de texto que contenga la lista de los archivos de video a unir. Creamos un archivo llamado files.txt
dentro de la misma carpeta donde están almacenados los videos
y agregamos los nombres de los archivos de video en él:
Donde fallout_video_frag1.mp4
y fallout_video_frag2.mp4
son los nombres de los archivos de video que deseas unir.
Ahora usaremos el filtro de concat
de FFmpeg para concatenar los archivos de video. El comando será similar al siguiente:
Explicación de los parámetros:
-f concat
: Especifica el formato de entrada como concat
, indicando que estás utilizando el filtro concat
.
-i files.txt
: Especifica el archivo de lista de concatenación como entrada.
-c copy
: Indica a FFmpeg que copie los flujos de audio y video sin volver a codificarlos, lo que preserva la calidad sin pérdidas.
resultado_concatenado.mp4
: Nombre del archivo de salida donde se guardará el video concatenado.
Vamos a trabajar con uno de los videos anteriores:
Para descargar solo la miniatura escribiremos:
Este comando le indica a yt-dlp
que no descargue el video (--skip-download
), pero que escriba la miniatura (--write-thumbnail
) del video y que lo descargue en jpg (--convert-thumbnails .jpg
).
La miniatura se guardará en el mismo directorio desde donde hemos ejecutado el comando:
Más información .
Por último, si escribes yt-dlp --help
verás toda la información sobre el comando o verlo .
Tienes más ejemplos disponibles en la propia .
A veces nos puede interesar convertir un archivo de audio o video de un formato a otro por ejemplo para su publicación web. tienes más información sobre formatos y códecs.
(o MPEG-4) - códec de video ampliamente utilizado que ofrece una buena calidad de compresión y es compatible con una amplia gama de dispositivos y plataformas.
(o HEVC) - evolución de H.264 que ofrece una mayor eficiencia de compresión, lo que significa que puede proporcionar una calidad de video comparable a una tasa de bits más baja o una mejor calidad de video a la misma tasa de bits.
(MPEG Audio Layer III): Usa un algoritmo de compresión con pérdida para reducir el tamaño de los archivos de audio eliminando algunas frecuencias de audio que son menos perceptibles para el oído humano.
(Advanced Audio Coding): códec de audio más moderno y avanzado en comparación con MP3. Usa un algoritmo de compresión con pérdida más eficiente que MP3, lo que permite obtener una mejor calidad de audio para un tamaño de archivo similar.
: su principal ventaja es que es un códec de audio de código abierto y libre de regalías. Al igual que MP3 y AAC, Vorbis utiliza un algoritmo de compresión con pérdida para reducir el tamaño de los archivos de audio. Sin embargo, se ha diseñado para proporcionar una calidad de audio similar o mejor que MP3 a tasas de bits más bajas.