qidao123.com技术社区-IT企服评测·应用市场

标题: FFmpeg 是什么?为什么?怎么用? [打印本页]

作者: 数据人与超自然意识    时间: 2025-2-23 06:33
标题: FFmpeg 是什么?为什么?怎么用?
择要:本文先容了 FFmpeg,一个功能强大的开源多媒体处理工具,广泛应用于视频和音频文件的处理。FFmpeg 支持多种多媒体格式,能够实现视频编码/解码、格式转换、裁剪、合并、音频提取、流媒体处理等功能。本文具体阐述了 FFmpeg 的主要组件、上风、安装方法、基本命令以及如何使用图形界面工具进行操作。

FFmpeg 是什么?为什么?怎么用?

一、FFmpeg 是什么?

FFmpeg 是一个开源的多媒体处理工具,广泛用于处理视频和音频文件。它支持险些所有常见的多媒体格式,包括但不限于视频编码/解码、视频转换、视频裁剪、音频提取、流媒体处理等。
FFmpeg 包含以下主要组件:


二、为什么需要 FFmpeg?


三、如何使用 FFmpeg?

1. 安装 FFmpeg

在 Windows 上安装 FFmpeg 的步调如下:



使用发起






  1. ffmpeg -version
复制代码


2. 基本命令

以下是一些常用的 FFmpeg 命令示例:
(1) 转换视频格式

将一个视频文件从 MP4 转换为 AVI:
  1. ffmpeg -i input.mp4 output.avi
复制代码
(2) 裁剪视频

裁剪视频的前 10 秒:
  1. ffmpeg -i input.mp4 -ss 00:00:00 -t 00:00:10 -c copy output.mp4
复制代码
(3) 调整视频分辨率

将视频分辨率调整为 1280x720:
  1. ffmpeg -i input.mp4 -s 1280x720 output.mp4
复制代码
(4) 提取音频

从视频中提取音频并保存为 MP3 文件:
  1. ffmpeg -i input.mp4 -q:a0-map a output.mp3
复制代码
(5) 合并视频和音频

将视频和音频文件合并:
  1. ffmpeg -i video.mp4 -i audio.mp3 -c:v copy -c:a aac output.mp4
复制代码
(6) 实时流处理

将摄像头视频流推送到 RTMP 服务器:
  1. ffmpeg -f v4l2 -i /dev/video0 -f alsa -i default -c:v libx264 -preset veryfast -maxrate 3000k -bufsize 6000k -pix_fmt yuv420p -g50-c:a aac -b:a 128k -ac2-ar44100-f flv rtmp://live.twitch.tv/app/stream_key
复制代码
(7) 数字人合成视频


项目实际案例分享:
  1. def main():
  2.     if not os.path.isfile(args.face):
  3.         raise ValueError('找不到数字人原始形象--face argument must be a valid path to video/image file')
  4.     elif args.face.split('.')[1] in ['jpg', 'png', 'jpeg']:
  5.         full_frames = [cv2.imread(args.face)]
  6.         fps = args.fps
  7.     else:
  8.         video_stream = cv2.VideoCapture(args.face)
  9.         fps = video_stream.get(cv2.CAP_PROP_FPS)
  10.         print('Reading video frames...')
  11.         full_frames = []
  12.         while 1:
  13.             still_reading, frame = video_stream.read()
  14.             if not still_reading:
  15.                 video_stream.release()
  16.                 break
  17.             if args.resize_factor > 1:
  18.                 frame = cv2.resize(frame, (frame.shape[1]//args.resize_factor, frame.shape[0]//args.resize_factor))
  19.             if args.rotate:
  20.                 frame = cv2.rotate(frame, cv2.cv2.ROTATE_90_CLOCKWISE)
  21.             y1, y2, x1, x2 = args.crop
  22.             if x2 == -1: x2 = frame.shape[1]
  23.             if y2 == -1: y2 = frame.shape[0]
  24.             frame = frame[y1:y2, x1:x2]
  25.             full_frames.append(frame)
  26.     print ("Number of frames available for inference: "+str(len(full_frames)))
  27.     if not args.audio.endswith('.wav'):
  28.         print('Extracting raw audio...')
  29.         command = 'ffmpeg -y -i {} -strict -2 {}'.format(args.audio, '../temp/temp.wav')
  30.         subprocess.call(command, shell=True)
  31.         args.audio = '../temp/temp.wav'
  32.     wav = audio.load_wav(args.audio, 16000)
  33.     mel = audio.melspectrogram(wav)
  34.     print(mel.shape)
  35.     if np.isnan(mel.reshape(-1)).sum() > 0:
  36.         raise ValueError('Mel contains nan! Using a TTS voice? Add a small epsilon noise to the wav file and try again')
  37.     mel_chunks = []
  38.     #TODO 与视频对应起来,每16,理论上来说,mel_idx_multiplier与mel_step_size相等,将音频分组,并获取与音频长度相等的视频帧
  39.     mel_idx_multiplier = 80./fps
  40.     i = 0
  41.     while 1:
  42.         start_idx = int(i * mel_idx_multiplier)
  43.         if start_idx + mel_step_size > len(mel[0]):
  44.             mel_chunks.append(mel[:, len(mel[0]) - mel_step_size:])
  45.             break
  46.         mel_chunks.append(mel[:, start_idx : start_idx + mel_step_size])
  47.         i += 1
  48.     print("Length of mel chunks: {}".format(len(mel_chunks)))
复制代码
3. 查看多媒体文件信息

使用 ffprobe 查看文件的具体信息:
  1. ffprobe input.mp4
复制代码
4. 图形界面工具

假如你不熟悉命令行操作,可以使用以下图形界面工具:
四、文章总结

FFmpeg 是一个功能强大的多媒体处理工具,适用于各种视频和音频处理任务。通过命令行操作,你可以轻松实现视频格式转换、裁剪、合并、音频提取等功能。假如你需要更直观的操作,也可以选择使用基于 FFmpeg 的图形界面工具。
五、相干分享

FFmpeg 的开源代码托管在 GitHub 上,你可以通过以下链接访问 FFmpeg 的开源地址:
GitHub - FFmpeg/FFmpeg: Mirror of https://git.ffmpeg.org/ffmpeg.git
1.如何使用 FFmpeg 源码

  1. git clone https://github.com/FFmpeg/FFmpeg.git
复制代码
开源地址:GitHub - FFmpeg/FFmpeg: Mirror of https://git.ffmpeg.org/ffmpeg.git


2.FFmpeg 官方文档





3.注意事项



4.常见问题办理


5.windows安装参考

如何在Windows上安装FFMPEG:完备的指南
How to install FFmpeg on Windows: a complete guide



免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 qidao123.com技术社区-IT企服评测·应用市场 (https://dis.qidao123.com/) Powered by Discuz! X3.4