FFmpeg常用命令详解与实战指南

1. 获取视频信息

使用FFmpeg获取视频信息是最基本的操作之一。你可以使用-i选项指定输入文件,然后使用FFmpeg内置的分析器来获取视频的各种信息,包括视频编解码器、音频编解码器、分辨率、帧率、码率等。

ffmpeg -i input.mp4

 结果:

Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'input.mp4':Metadata:major_brand     : mp42minor_version   : 0compatible_brands: mp42isomavc1creation_time   : 2024-03-12T03:09:36.000000ZDuration: 00:00:22.93, start: 0.000000, bitrate: 24425 kb/sStream #0:0[0x1](und): Video: h264 (High) (avc1 / 0x31637661), yuv420p(tv, bt709, progressive), 3840x2160, 24422 kb/s, 30 fps, 30 tbr, 30 tbn (default)Metadata:creation_time   : 2024-03-12T03:09:36.000000Zhandler_name    : Vimeo Artax Video Handlervendor_id       : [0][0][0][0]encoder         : AVC Coding
  • 文件类型:mov, mp4, m4a, 3gp, 3g2, mj2 (这些都是 MPEG-4 媒体容器格式)
  • 创建时间:2024年3月12日,03:09:36
  • 持续时间:00:00:22.93
  • 视频流信息:
    • 编解码器:h264 (High),也就是 AVC (Advanced Video Coding),通常称为 H.264
    • 视频像素格式:yuv420p,色彩空间为 YUV,采样结构为 4:2:0,色度信息被降采样
    • 视频分辨率:3840x2160,即 4K 分辨率
    • 比特率:24422 kb/s
    • 帧率:30 帧每秒 (fps)
    • 时间基:30 tbr (帧率)、30 tbn
    • 其他元数据信息:包括创建时间、处理程序名称、供应商 ID、编码器等

2. 音视频分离

音视频分离是指将视频文件中的视频流和音频流分别提取出来。你可以使用FFmpeg的-vn(禁用视频流)和-an(禁用音频流)选项来实现这一功能。

# 提取视频流
ffmpeg -i input.mp4 -vn output_audio.mp3
# 提取视频流
ffmpeg -i input.mp4 -an output_video.mp4

将test.mp4和tmp.mp3音视频合并 

# 确保音频流就是mp3的才可以这么干
ffmpeg -i "test.mp4" -vn -c:a copy "tmp.mp3"

3. 转换音视频格式

FFmpeg支持将音视频文件转换为各种常见的格式,如MP4、FLV、AVI、MOV等。你可以使用-f选项指定输出格式,使用-vcodec-acodec选项分别指定视频编解码器和音频编解码器。

MP4转FLV

ffmpeg -i input.mp4 -codec copy output.flv

MP4转AVI

ffmpeg -i input.mp4 output.avi

MP4转MOV 

ffmpeg -i input.mp4 output.mov

4. 视频裁剪与拼接

FFmpeg提供了强大的视频裁剪和拼接功能。你可以使用-ss选项指定裁剪的起始时间,使用-t选项指定裁剪的持续时间,使用-to选项指定裁剪的结束时间。对于视频拼接,你可以使用多个输入文件,并指定输出文件。

裁剪视频(从第10秒开始,持续10秒)

ffmpeg -i input.mp4 -ss 00:00:10 -t 10 output.mp4

视频拼接(将两个视频文件拼接成一个)

ffmpeg -i input1.mp4 -i input2.mp4 output.mp4

5. 视频转码

视频转码是指将视频文件转换为不同的编解码器或分辨率。你可以使用-vcodec选项指定视频编解码器,使用-vf选项指定视频滤镜来调整分辨率、帧率等参数。

将MP4视频转码为H.264编码的MKV文件:

ffmpeg -i input.mp4 -vcodec libx264 output.mkv

调整视频分辨率:

ffmpeg -i input.mp4 -vf scale=640:480 output.mp4

6. 音频处理

除了视频处理外,FFmpeg还提供了丰富的音频处理功能,包括音频转码、音频提取、音频剪辑等。你可以使用-acodec选项指定音频编解码器,使用-af选项指定音频滤镜来处理音频数据。

提取视频中的音频并转码为MP3格式

ffmpeg -i input.mp4 -vn -acodec libmp3lame output.mp3

音频剪辑(从第30秒开始,持续10秒) 

ffmpeg -i input.mp3 -ss 00:00:30 -t 10 output.mp3

调整视频大小

ffmpeg -i input.mp4 -vf scale=640:480 output.mp4

视频截图

ffmpeg -i input.mp4 -ss 00:00:10 -vframes 1 screenshot.jpg

 9 音频转码

ffmpeg -i input.wav -b:a 192K output.mp3

 10 合并视频

原视频包含音频和视频信息情况下:

ffmpeg -i input1.mp4 -i input2.mp4 -filter_complex "[0:v][0:a][1:v][1:a]concat=n=2:v=1:a=1[outv][outa]" -map "[outv]" -map "[outa]" output.mp4

单独合并视频信息:

 去掉a,直接对v进行合并

ffmpeg -i input.mp4 -i output.mp4 -filter_complex "[0:v][1:v]concat=n=2:v=1[outv]" -map "[outv]"  output2.mp4

11 m3u8生成

ffmpeg -i input.mp4 -c:v copy -c:a copy -f hls -hls_time 10 output.m3u8

 -c:v copy-c:a copy 参数表示视频和音频流不进行重新编码

-hls_time 控制每个TS文件的时长,-hls_list_size 控制M3U8文件中最多保留的TS文件数目

指定为每一个ts指定baseurl

ffmpeg -i input.mp4 -c:v copy -c:a copy -f hls -hls_time 10 -hls_base_url http://example.com/videos/ output.m3u8

生成内容:

 

12 m3u8转音频视频

视频:

ffmpeg -protocol_whitelist "file,http,https,tcp,tls" -i input.m3u8 -c copy output.mp4

-protocol_whitelist 参数允许FFmpeg使用指定的协议(在这里是 "file", "http", "https", "tcp", "tls")来下载TS文件。 -c copy 参数表示不对视频进行重新编码,只是直接将输入流复制到输出文件中。 

音频: 

ffmpeg -protocol_whitelist "file,http,https,tcp,tls" -i input.m3u8 -map 0:a -c copy output.mp3

 -map 0:a 参数用于选择第一个输入文件(M3U8文件)的所有音频流。-c copy 参数表示不对音频进行重新编码

13 m3u8生成指定时间的音频视频

# 提取视频
ffmpeg -protocol_whitelist "file,http,https,tcp,tls" -ss 00:01:30 -i input.m3u8 -t 60 -c:v copy -c:a copy output_video.mp4# 提取音频
ffmpeg -protocol_whitelist "file,http,https,tcp,tls" -ss 00:01:30 -i input.m3u8 -t 60 -vn -c:a copy output_audio.mp3

 测试越多越感觉ffmpeg功能好强大,简直能满足对音视频的大多需求

参数说明

选项说明
-h显示基本选项。
-h long显示更多选项。
-h full显示所有选项(包括所有格式和编解码器特定选项,非常长)。
-h type=name显示指定解码器/编码器/解封装器/封装器/过滤器/比特流过滤器/协议的所有选项。
-L显示许可证信息。
-version显示版本信息。
-muxers显示可用的封装器。
-demuxers显示可用的解封装器。
-devices显示可用设备。
-decoders显示可用的解码器。
-encoders显示可用的编码器。
-filters显示可用的过滤器。
-pix_fmts显示可用的像素格式。
-layouts显示标准声道布局。
-sample_fmts显示可用的音频采样格式。
-v <loglevel>设置日志级别。
-y覆盖输出文件。
-n永不覆盖输出文件。
-stats在编码过程中打印进度报告。
-f <fmt>强制指定容器格式(否则自动检测)。
-t <duration>在指定持续时间后停止转码。
-to <time_stop>在达到指定时间后停止转码。
-ss <time_off>从指定时间开始转码。
-metadata添加元数据。
-r重写输入帧速率/转换为指定输出帧速率。
-aspect设置宽高比。
-vn禁用视频。
-vcodec选择视频流的编码器/解码器。
-vf应用视频流的指定滤镜。
-b视频比特率。
-aq设置音频质量(特定于编解码器)。
-ar设置音频采样率。
-ac设置音频通道数。
-an禁用音频。
-acodec选择音频流的编码器/解码器。
-ab音频比特率。
-af应用音频流的指定滤镜。
-sn禁用字幕。
-scodec选择字幕流的编码器/解码器。

HLS M3U8参数:

参数说明
-hls_time <duration>指定每个TS文件的时长。例如,-hls_time 10 表示每个TS文件的时长为10秒。
-hls_list_size <number>指定M3U8播放列表中最多包含的TS文件数目。当生成的TS文件数量超过这个值时,旧的TS文件将被删除。例如,-hls_list_size 5 表示M3U8播放列表最多包含5个TS文件。
-hls_segment_filename <pattern>指定TS文件的命名模式。默认情况下,FFmpeg会根据输入文件的名称生成TS文件,但您也可以使用这个选项来自定义TS文件的命名。例如,-hls_segment_filename file_%03d.ts 将生成形如 file_001.tsfile_002.ts 等命名的TS文件。
-hls_base_url <url>指定TS文件在服务器上的基本URL。当客户端请求TS文件时,会使用这个URL与TS文件名拼接成完整的URL。例如,-hls_base_url http://example.com/videos/ 将使用 http://example.com/videos/ 作为TS文件的基本URL。
-hls_flags <flags>指定一些HLS相关的标志。常见的标志包括: split_by_timeomit_endlist等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/669643.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二维码链接如何获取?分解二维码链接的方法

现在使用二维码的方式来展示内容越来越常见&#xff0c;二维码可以实现多人同时扫码获取自己需要的内容&#xff0c;有效提升内容的传播速度&#xff0c;而且成本低。但是在某些情况下&#xff0c;无法通过扫描设备查看二维码内容&#xff0c;那么可以通过获取二维码链接来访问…

多级留言/评论的功能实现——SpringBoot3后端篇

目录 功能描述数据库表设计后端接口设计实体类entity 完整实体类dto 封装请求数据dto 封装分页请求数据vo 请求返回数据 Controller控制层Service层接口实现类 Mapper层Mybatis 操作数据库 补充&#xff1a;返回的数据结构自动创建实体类 最近毕设做完了&#xff0c;开始来梳理…

“全国首批EVO+ ICL(V5)临床应用专家”授牌仪式在铭依眼科举行

近日&#xff0c;“全国首批EVO ICL&#xff08;V5&#xff09;新技术临床应用专家”授牌仪式在上海铭依眼科门诊部举行。仪式现场&#xff0c;瑞金医院谢冰教授获得此项荣誉称号。铭依眼科连锁医疗机构创始人吴英、Staar Surgical代表出席仪式现场。 为让近视人群不出国门即可…

MySql#MySql安装和配置

目录 一、卸载不需要的环境 二、安装mysql yum 源 三、开始安装 四、如果保证安装成功呢&#xff1f; 五、MySql 启动&#xff01; 六、登录mysql 七、配置文件说明 八、设置开机启动&#xff01; 本次安装是在Linux环境在centos7中完成 首先先将自己切换成root 一、…

国内外主流大模型都具备有哪些特点?

文章目录 ⭐ 火爆全网的大模型起点⭐ 国外主流LLM及其特点⭐ 国内主流LLM及其特点⭐ 全球大模型生态的发展 该章节呢&#xff0c;我们主要是看一下关于国内外主流的大语言模型&#xff0c;通过它们都具备哪些特点&#xff0c;来达成对多模型有一个清晰的认知。对于 “多模型” …

信创 | 信创产业全解析:一篇文章带你深入了解!

01、信创产业的前世今生 近几年&#xff0c;“信创”、“国产替代”、“适配”等关键词已成为IT领域以及众多行业热议的词汇&#xff0c;被业内人士频繁提及。要想知道这些关键词的内涵&#xff0c;了解其对我们的生产生活以及对各行业发展趋势的影响&#xff0c;我们可以通过…

深度学习:基于Keras,使用长短期记忆神经网络模型LSTM和RMSProp优化算法进行销售预测分析

前言 系列专栏&#xff1a;【机器学习&#xff1a;项目实战100】【2024】✨︎ 在本专栏中不仅包含一些适合初学者的最新机器学习项目&#xff0c;每个项目都处理一组不同的问题&#xff0c;包括监督和无监督学习、分类、回归和聚类&#xff0c;而且涉及创建深度学习模型、处理非…

图像处理技术与应用(四)

图像处理技术与应用入门 颜色空间及其转换 颜色空间是一种用于在数字图像中表达和指定颜色的方法。不同的颜色空间使用不同的方式来定义颜色&#xff0c;每种方式都有其特定的用途和优势。以下是一些常见的颜色空间及其特点&#xff1a; RGB&#xff08;红绿蓝&#xff09;&a…

一文彻底讲透 CSS 盒模型

文章导读&#xff1a;AI 辅助学习前端&#xff0c;包含入门、进阶、高级部分前端系列内容&#xff0c;当前是 CSS 的部分&#xff0c;瑶琴会持续更新&#xff0c;适合零基础的朋友&#xff0c;已有前端工作经验的可以不看&#xff0c;也可以当作基础知识回顾。 CSS 盒模型&…

正则表达式-前瞻和后顾

正则表达式中的前瞻和后顾。 前瞻(Lookahead) 前瞻是一种断言,它会检查在当前位置之后是否存在某种模式,但不会实际匹配该模式。前瞻有两种形式: 正向前瞻 (?pattern) 检查当前位置之后是否存在指定的模式如果存在,则匹配成功,但不会消耗该模式例如 \w(?\d) 将匹配后面跟数…

Elasticsearch安装IK分词器

系列文章目录 文章目录 系列文章目录前言前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码吧。 Elasticsearch 是一个分布式、RESTful 风格的搜索和数据分析引擎,能够解…

大数据实验 实验四:NoSQL 和关系数据库的操作比较

NoSQL 和关系数据库的操作比较 实验目的 理解四种数据库(MySQL、HBase、Redis 和 MongoDB)的概念以及不同点&#xff1b;熟练使用四种数据库操作常用的 Shell 命令&#xff1b;熟悉四种数据库操作常用的 Java API。 实验平台 操作系统&#xff1a;centos7Hadoop 版本&#…