当前位置: 首页 > news >正文

视频行为分析——视频图像转换与ffmpeg相关操作

工具类说明

1. 图像视频转换

1.1 视频输出gif

from moviepy.editor import VideoFileClip
# 设置输入视频文件路径和输出GIF文件路径
input_video = 'video.avi'
output_gif = 'output.gif'
# 读取视频文件
video = VideoFileClip(input_video)
# 将视频保存为GIF文件
video.write_gif(output_gif)

1.2 将文件夹下图片转视频

import cv2
import os
def images2video(    input_folder = 'demo',    output_file = 'video.avi'):# 获取图像文件的列表image_files = os.listdir(input_folder)# 将图像文件名列表按照数字排序image_files.sort(key=lambda x: int(x.split('.')[0]))# 获取图像文件的数量num_frames = len(image_files)# 创建一个空的视频流fourcc = cv2.VideoWriter_fourcc(*'XVID')  # 设置视频编解码器out = cv2.VideoWriter(output_file, fourcc, 30.0, (640, 480))# 逐个读取并写入每个图像帧for i, image_file in enumerate(image_files):frame = cv2.imread(os.path.join(input_folder, image_file))if frame is None:print(f"Error reading frame {i}: {image_file}")continueframe = cv2.resize(frame, (640, 480))  # 可以根据需要调整帧大小out.write(frame)if i % 100 == 0:  # 每100帧输出一次进度信息print(f"Processed {i + 1}/{num_frames} frames")# 完成视频写入并释放资源out.release()

2. ffmpeg视频音频剪辑

2.1 ffmpeg安装

FFmpeg 的官方网站(https://ffmpeg.org/)上找到更详细的安装文档和指南。

2.1.1 linux 安装

  • 编译安装:如果你需要更新或自定义的 FFmpeg 版本,你可以从源代码编译安装。你可以从 FFmpeg 的官方网站下载源代码,并按照官方提供的编译指南进行安装。
  • 使用包管理器安装:大多数 Linux 发行版的软件仓库中都包含 FFmpeg。你可以使用包管理器(如apt、yum、dnf等)来安装。例如,在 Ubuntu 上,可以运行以下命令:
     sudo apt-get install ffmpeg

2.1.2 windows 安装

  • 预编译二进制文件:你可以从 FFmpeg 的官方网站下载预编译的 Windows 版本。官方提供了静态和共享库版本的二进制文件,你可以根据需要选择适合的版本。
  • 第三方安装程序:也有一些第三方安装程序(如Gyan Dev和BtbN)提供了 Windows 版本的 FFmpeg,你可以从它们的网站下载并按照说明进行安装。
  • 备注:需要将bin目录下设置到windows环境变量

2.1.3 macos 安装

  • Homebrew:如果你使用 Homebrew 包管理器,可以使用以下命令安装 FFmpeg

     brew install ffmpeg
    
  • MacPorts:如果你使用 MacPorts 包管理器,可以使用以下命令安装 FFmpeg

     sudo port install ffmpeg
    
  • 手动编译:你也可以从 FFmpeg 的官方网站下载源代码,并按照官方提供的编译指南进行手动编译安装。

2.2 常用命令

FFmpeg 是一个功能强大的多媒体处理工具,提供了许多常用的命令来处理音频和视频文件。以下是一些常用的 FFmpeg 命令示例:

2.2.1 转换视频格式

ffmpeg -i input.mp4 output.avi

2.2.2 转换音频格式

ffmpeg -i input.mp3 output.wav

2.2.3 调整视频分辨率

ffmpeg -i input.mp4 -s 1280x720 output.mp4

2.2.4 调整视频帧率

ffmpeg -i input.mp4 -r 30 output.mp4

2.2.5 裁剪视频

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

2.2.6 提取音频

ffmpeg -i input.mp4 -vn output.mp3

2.2.7 合并视频和音频

ffmpeg -i video.mp4 -i audio.mp3 -c:v copy -c:a copy output.mp4

2.2.8 添加水印

ffmpeg -i input.mp4 -i watermark.png -filter_complex "overlay=10:10" output.mp4	

2.2.9 转换视频编码

ffmpeg -i input.mp4 -c:v libx264 -crf 23 output.mp4

2.2.10 转换音频编码

ffmpeg -i input.mp3 -c:a libopus output.opus

2.3 实用工具

2.3.1 按照帧裁剪视频

'''
使用 setpts=PTS-STARTPTS 可以将视频的第一帧的时间戳设置为0,这样后续帧的时间戳就是相对于第一帧的时间差。这在一些需要对视频进行时间戳调整的场景中非常有用,例如剪辑视频或重新排序视频帧。
'''def ffmpeg_cut_video_by_frames(input_file, output_file, start_frame, end_frame):# 构建 FFmpeg 命令# 示例用法'''input_file = 'demo.mp4'  # 输入视频文件路径output_file = 'output2.mp4'  # 输出视频文件路径start_frame = 25  # 起始帧数end_frame = 120  # 结束帧数'''command = ['ffmpeg','-i', input_file,'-vf', f'select=between(n\,{start_frame}\,{end_frame}),setpts=PTS-STARTPTS',output_file,]if os.path.exists(output_file):os.remove(output_file)# 执行 FFmpeg 命令flag = subprocess.run(command)return flagif __name__ == '__main__':# 示例用法input_file = 'demo.mp4'  # 输入视频文件路径output_file = 'output2.mp4'  # 输出视频文件路径start_frame = 25  # 起始帧数end_frame = 120  # 结束帧数ffmpeg_cut_video_by_frames(input_file, output_file, start_frame, end_frame)

相关文章:

视频行为分析——视频图像转换与ffmpeg相关操作

工具类说明 1. 图像视频转换 1.1 视频输出gif from moviepy.editor import VideoFileClip # 设置输入视频文件路径和输出GIF文件路径 input_video video.avi output_gif output.gif # 读取视频文件 video VideoFileClip(input_video) # 将视频保存为GIF文件 video.write_…...

Bean 生命周期

Bean 生命周期 一、Bean 实例化的基本流程 Spring容器在进行初始化时,会将xml配置的的信息封装成一个BeanDefifinition对象,所有的BeanDefifinition存储到一个名为beanDefifinitionMap的Map集合中去,Spring框架在对该Map进行遍历&#xff0…...

JavaScript原型链污染

前言 在浏览某个论坛的时候,第一次看到了JavaScript原型链污染漏洞。当时非常的好奇,当时我一直以为js作为一种前端语言,就算存在漏洞也是针对前端,不会危害到后端,因此我以为这种漏洞危害应该不大。可当我看到他的漏…...

【Java】设计模式之单例模式与工厂模式

1、设计模式概念及分类 简单来说设计模式是被广大程序员们总结并认可的编码套路,其中最常用的莫过于单例模式与工厂模式,而单例模式也有更加细的分类,一起来学习一下这些模式的用法和特点吧。 2、单例模式 一个类只能被实例化出来一个对象…...

web自动化框架:selenium学习使用操作大全(Python版)

目录 一、浏览器驱动下载二、selenium-python安装(打开网站、操作元素)三、网页解析(HTML、xpath)四、selenium基本操作1、元素定位八种方法2、元素动态定位3、iframe切换4、填充表单_填充文本框5、填充表单_单选按钮6、填充表单_…...

boringssl EVP_aes_128_ecb实现

最近学习boringssl,发现没找到EVP_aes_128_ecb在哪里实现的 饶了一大圈,发现它的定义很无语 #define EVP_CIPHER_FUNCTION(keybits, mode) \const EVP_CIPHER *EVP_aes_##keybits##_##mode(void) { \return aes_##keybits##_##mode##_gene…...

vxe-table中树形结构

如图,同事让帮忙实现一个需求 从二级树节点开始,同时选中的只能有一个二级树节点,选中的二级树节点之下的子节点都可以被选中。否则不能被选中 直接上代码 需要注意的是,文中树状图传递的数据是打平的数据,设置代码是…...

Linux命令查看CPU、内存、IO使用情况简单介绍

文章目录 1. CPU相关介绍1.1 物理CPU1.2 物理CPU内核1.3 逻辑CPU1.4 几核几线程1.5 CPU设计图 2. top 查看系统负载、CPU使用情况2.1 系统整体的统计信息2.2 进程信息2.3 top命令使用 3. lscpu 显示有关 CPU 架构的信息4. free 查看内存信息5. iostat 查看io信息 1. CPU相关介绍…...

RPC框架的核心是什么

文章目录 什么是 RPC封装的艺术(如何隐藏底层逻辑)协议的实现序列化和反序列化(编解码)总结 什么是 RPC 首先思考这样一个问题,假设你不知道任何框架,现在有两台机器,每台机器上有一个服务&…...

直播、AI赋能,美团披着荆棘前行

随着互联网流量红利逐渐消退,阿里、抖音、腾讯、拼多多、快手、小红书等各赛道玩家,为了寻求新的增量,纷纷“卷”向本地生活,开始入侵美团的腹地。然而,哪怕巨头环伺,美团仍然展现出了其独特的竞争力&#…...

提升代码逻辑的感觉——python循环语句

提升代码逻辑的感觉——python循环语句 简介 循环是编程中的一个非常重要的概念,它用于处理重复性任何和迭代草错,通过循环我们能优化并简化代码,提高代码的可维护性,在Python中循环是一种控制结构,允许我们重复执行…...

【ARM Coresight 系列文章 20 -- linux perf 与 ARM coresight】

文章目录 1.1 Perf Introduction1.1.1 Perf 架构图1.1.2 Perf Tools 介绍1.1.3 Perf 命令介绍1.2 Events1.2.1 Perf 与 PMU 的关系1.2.2 Hardware events1.2.1.1 linux perf 事件分类1.2.2 Software Events1.2.3 Tracepoint Events1.3 Perf 工具使用1.4 用户态开发1.4.1 用户态…...

微服务之Nacos

1 版本说明 官网地址: https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E 1.1 2021.x 分支 适配 SpringBoot 2.4, Spring Cloud 2021.x 版本及以上的Spring Cloud Alibaba 版本如下表(最新版本用*标记&am…...

jvm 新生代的区域划分

虚拟机将内存分为一块较大的 Eden 空间和两块较小的 Survivor 空间,每次分配内存只使用 Eden 和其中一块 Survivor。发生垃圾收集时,将 Eden 和 Survivor 中仍然存活的对象一次性复制到另外一块 Survivor 空间上,然后直接清理掉 Eden 和已用过…...

【C++】对于string的补充(成员函数c_str()、大小写转换、字符串和实数之间的相互转换)

前言 本篇文章记录的是一些关于string的补充说明 string与const char*之间的相互转换 const char* 转换成string 在C中存在着从const char到string的隐式类型转换,换句话说,如果一个函数的参数类型是string类,直接传入const char类型的参…...

华为OD机试真题【羊狼农夫过河】

1、题目描述 【羊、狼、农夫过河】 羊、狼、农夫都在岸边,当羊的数量小于狼的数量时,狼会攻击羊,农夫则会损失羊。农夫有一艘容量固定的船,能够承载固定数量的动物。要求求出不损失羊情况下将全部羊和狼运到对岸需要的最小次数。…...

【线性代数-3Blue1Brown】- 5 三维空间的线性变换

飞书原文档:Docs...

Maven入门教程(二):idea/Eclipse使用Maven

Maven入门教程(一):安装Maven环境 4.开发工具配置 4.1 idea配置 idea有多个版本,配置是一样的,只是配置页面的入口不一样 旧版idea 新版idea 4.2 Eclipse配置 打开Eclipse,菜单中选择:Window -> Preference ->…...

【MySQL】MySQL里的用户账户和角色是什么?如何管理?

用户(user)验证和授权创建用户账户连接服务器查看用户账户设置 角色(role)创建角色 操作用户帐户和角色重命名删除 感谢 💖 用户(user) 在MySQL中,用户是数据库访问的主要实体。每个…...

vbs病毒

vbs脚本:VBS脚本病毒原理分析和防范 疯狂代码 http://CrazyCoder.cn/ Sh t t p : / C r a z y C o d e r . c n / S e c u r i t y / Ar t i c l e 7 2 0 0 8 . h t m l 网络流行让我们世界变得更加美好但它也有让人不愉快时候当您收到封主题为1LoveYou” 邮件用兴奋 得几乎快发…...

HTML 语义化

目录 HTML 语义化HTML5 新特性HTML 语义化的好处语义化标签的使用场景最佳实践 HTML 语义化 HTML5 新特性 标准答案&#xff1a; 语义化标签&#xff1a; <header>&#xff1a;页头<nav>&#xff1a;导航<main>&#xff1a;主要内容<article>&#x…...

大型活动交通拥堵治理的视觉算法应用

大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动&#xff08;如演唱会、马拉松赛事、高考中考等&#xff09;期间&#xff0c;城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例&#xff0c;暖城商圈曾因观众集中离场导致周边…...

(转)什么是DockerCompose?它有什么作用?

一、什么是DockerCompose? DockerCompose可以基于Compose文件帮我们快速的部署分布式应用&#xff0c;而无需手动一个个创建和运行容器。 Compose文件是一个文本文件&#xff0c;通过指令定义集群中的每个容器如何运行。 DockerCompose就是把DockerFile转换成指令去运行。 …...

AspectJ 在 Android 中的完整使用指南

一、环境配置&#xff08;Gradle 7.0 适配&#xff09; 1. 项目级 build.gradle // 注意&#xff1a;沪江插件已停更&#xff0c;推荐官方兼容方案 buildscript {dependencies {classpath org.aspectj:aspectjtools:1.9.9.1 // AspectJ 工具} } 2. 模块级 build.gradle plu…...

Java线上CPU飙高问题排查全指南

一、引言 在Java应用的线上运行环境中&#xff0c;CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时&#xff0c;通常会导致应用响应缓慢&#xff0c;甚至服务不可用&#xff0c;严重影响用户体验和业务运行。因此&#xff0c;掌握一套科学有效的CPU飙高问题排查方法&…...

JVM 内存结构 详解

内存结构 运行时数据区&#xff1a; Java虚拟机在运行Java程序过程中管理的内存区域。 程序计数器&#xff1a; ​ 线程私有&#xff0c;程序控制流的指示器&#xff0c;分支、循环、跳转、异常处理、线程恢复等基础功能都依赖这个计数器完成。 ​ 每个线程都有一个程序计数…...

【Redis】笔记|第8节|大厂高并发缓存架构实战与优化

缓存架构 代码结构 代码详情 功能点&#xff1a; 多级缓存&#xff0c;先查本地缓存&#xff0c;再查Redis&#xff0c;最后才查数据库热点数据重建逻辑使用分布式锁&#xff0c;二次查询更新缓存采用读写锁提升性能采用Redis的发布订阅机制通知所有实例更新本地缓存适用读多…...

基于Java+VUE+MariaDB实现(Web)仿小米商城

仿小米商城 环境安装 nodejs maven JDK11 运行 mvn clean install -DskipTestscd adminmvn spring-boot:runcd ../webmvn spring-boot:runcd ../xiaomi-store-admin-vuenpm installnpm run servecd ../xiaomi-store-vuenpm installnpm run serve 注意&#xff1a;运行前…...

如何应对敏捷转型中的团队阻力

应对敏捷转型中的团队阻力需要明确沟通敏捷转型目的、提升团队参与感、提供充分的培训与支持、逐步推进敏捷实践、建立清晰的奖励和反馈机制。其中&#xff0c;明确沟通敏捷转型目的尤为关键&#xff0c;团队成员只有清晰理解转型背后的原因和利益&#xff0c;才能降低对变化的…...

安卓基础(Java 和 Gradle 版本)

1. 设置项目的 JDK 版本 方法1&#xff1a;通过 Project Structure File → Project Structure... (或按 CtrlAltShiftS) 左侧选择 SDK Location 在 Gradle Settings 部分&#xff0c;设置 Gradle JDK 方法2&#xff1a;通过 Settings File → Settings... (或 CtrlAltS)…...