基于Node.js 和 FFmpeg构建自动化脚本用来转码视频

这篇具有很好参考价值的文章主要介绍了基于Node.js 和 FFmpeg构建自动化脚本用来转码视频。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

这个脚本将监控一个特定的目录,自动转码新添加的视频文件,并将转码后的视频保存到指定目录。

准备环境

  1. 安装 Node.js:

    • 访问 Node.js 官网,下载并安装适合你操作系统的 Node.js 版本。
  2. 安装 FFmpeg(不清楚的可以看我的上篇博客里有详细的安装步骤):

    • 对于 Windows 用户,可以从 FFmpeg 官方网站下载预编译的二进制文件,解压,并将 bin 目录添加到系统的环境变量中。
    • macOS 用户可以使用 Homebrew 安装:brew install ffmpeg
    • Linux 用户(以 Ubuntu 为例)可以使用:sudo apt install ffmpeg

设置项目

  1. 在你的开发目录中,创建一个新的目录作为项目文件夹,如 video-transcoder

  2. 打开终端或命令提示符,进入该目录,并初始化一个新的 Node.js 项目:

    cd path/to/video-transcoder
    npm init -y
    
  3. 安装 fluent-ffmpegchokidar(用于监控文件系统变化的库):

    npm install fluent-ffmpeg chokidar
    

编写转码脚本

在项目目录中创建一个名为 transcode.js 的文件,并添加以下内容:

const fs = require('fs');
const path = require('path');
const ffmpeg = require('fluent-ffmpeg');
const chokidar = require('chokidar');

// 设置监控的目录和输出目录
const watchDir = path.join(__dirname, 'watch');
const outputDir = path.join(__dirname, 'output');

// 确保输出目录存在
if (!fs.existsSync(outputDir)) {
    fs.mkdirSync(outputDir, { recursive: true });
}

// 监控目录中的新文件
chokidar.watch(watchDir).on('add', (filePath) => {
    // 确保文件是视频(这里简单以文件扩展名为准,可根据需要调整)
    if (path.extname(filePath).match(/\.(mp4|mov|avi)$/)) {
        console.log(`Detected new video for transcoding: ${filePath}`);
        
        // 设置输出文件路径
        const outputFilePath = path.join(outputDir, path.basename(filePath, path.extname(filePath)) + '_converted.mp4');
        
        // 使用 FFmpeg 进行转码
        ffmpeg(filePath)
            .output(outputFilePath)
            .videoCodec('libx264') // 使用 x264 编码
            .audioCodec('aac') // 使用 AAC 音频编码
            .on('end', () => console.log(`Transcoding finished: ${outputFilePath}`))
            .on('error', (err) => console.error(`Transcoding error: ${err.message}`))
            .run();
    }
});

console.log(`Watching for videos to transcode in: ${watchDir}`);

这段脚本做了几件事:

  • 使用 chokidar 库监控 watchDir 目录下的新添加文件。
  • 当检测到新文件时,判断是否为视频文件(通过文件扩展名)。
  • 如果是视频文件,使用 fluent-ffmpeg 将其转码为使用 H.264 编码的 MP4 文件,并保存到 outputDir 目录。
  • 在转码过程中,通过事件监听器输出转码进度和结果。

运行脚本

  1. video-transcoder 目录中,确保有 watchoutput 两个子目录。将你想要自动转码的视频文件放入 watch 目录。

  2. 在命令行中运行你的脚本:

    node transcode.js
    
  3. 脚本会自动检测 watch 目录中的新视频文件,并开始转码过程,转码后的视频将保存在 output 目录。

结语

通过上述步骤,你已经创建了一个可以自动监控目录并转码视频的Node.js脚本。这个脚本可以根据你的特定需求进一步定制和扩展,例如添加更多的转码选项、处理更多视频格式、或者在转码完成后发送通知等。这只是展示了FFmpeg和Node.js在视频处理自动化方面强大功能的冰山一角。随着你对这些工具的深入了解,你将能够解锁更多的可能性,以适应日益增长的多媒体处理需求。文章来源地址https://www.toymoban.com/news/detail-843920.html

到了这里,关于基于Node.js 和 FFmpeg构建自动化脚本用来转码视频的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

原文地址:https://blog.csdn.net/wanghaoyingand/article/details/136573710

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • js脚本自动化之 【 i茅台 】让你解放双手

    ![青龙面板跑的结果](https://img-blog.csdnimg.cn/15070a54904a4ab9808c66ba7521d6eb.jpeg ----------------------------------------------------------------------------------- 专栏分割线 ------------------------------------------------------------------------------------ ---------------------------------------------------------------------------------

    2024年02月02日
    浏览(13)
  • 简单的Shell脚本实现自动化构建部署-适合前后端分离的小网站

    大家在生活中经常会自己写一点小代码。然后部署在公有云的服务器上。但是一般像阿里,腾讯等服务商,提供的机器内存并不是很大。如果想装入一个jenkins之类的服务,会比较占用CPU和内存的资源。但是人手的部署又是比较麻烦的。所以我这里提供了一个思路,使用shell脚

    2023年04月16日
    浏览(15)
  • Auto.js安卓脚本自动化app的代码语句大全

    (一)常用 (二)点击 (三)按住随机滑动 (四)控制台 (五)用线程自动开启截图权限 (六)读写权限 (一)位置 (二)判断点击 (二)输出当前页面所有文本 1、text函数 2、bounds函数

    2024年02月15日
    浏览(7)
  • 网页JS自动化脚本(一)安装油猴或暴力猴等脚本管理器并新建脚本

    在我们的工作生活当中使用网页的机会越来越高,很多时候要进行重复的操作,所以进行一些JS脚本就成了可选项 首先我们要在网页浏览器中安装上脚本管理器,这里示范的是安装暴力猴,是一个开源的免费的小软件,是在github上的一款软件,下载下来之后名称为 Violentmonkey_2.13.0_ch

    2024年02月04日
    浏览(8)
  • auto.js autojs pro9 autox.js实现adb自动化测试脚本开发自动生成代码 防无障碍检测

    不需要开无障碍就可以实现自动化 ,功能上和无障碍效果一样, 但是可以过目标app的检测,因为软件基本上都不检测adb(usb调试), 游戏脚本的福音 ,最主要是可以 直接生成自动化代码 ,所以写adb的自动化脚本 和无障碍的自动化脚本都同样简单高效,傻瓜式操作。 对于

    2024年01月19日
    浏览(19)
  • Vue.js 学习14 集成H265web.js播放器实现webpack自动化构建

    H265web.js 是一个用于在 Web 浏览器中播放 H.265 视频的 JavaScript 播放器。它支持在浏览器中直接解码 H.265 编码的视频流,提供了高效的视频播放体验。在 Element UI 项目中集成 H265web.js 可以让我们轻松实现 H.265 视频的播放功能。 H265web.js 开源地址: https://github.com/numberwolf/h265web

    2024年03月14日
    浏览(25)
  • DevOps—基于 Jenkins 构建 Vue 前端工程自动化流程

    一个完整的生产环境的 CI/CD 流程,往往会包括以下这些阶段: 编码 → 提交 → 构建 → 测试 → 交付 → 部署 这里只是演示,就省略了测试相关阶段,只包含提交、构建、发布、部署,一个简单的流程如下: vue 应用构建依赖于 Nodejs,需要在 Jenkins 上安装 Nodejs 插件,并且进

    2024年02月15日
    浏览(8)
  • 基于自动化工具autox.js的抢票(猫眼)

    1.看到朋友圈抢周杰伦、林俊杰演唱会票贼难信息,特研究了一段时间,用autox.js写了自动化抢票脚本,购票页面自动点击下单(仅限安卓手机)。 2.脚本运行图 3.前期准备工作  (1)autox.js社区官网:AutoX.js  (2)b站上学习资料:10分钟学会AutoX.js hello world_哔哩哔哩_bilibil

    2024年02月04日
    浏览(10)
  • 基于Docker构建CI/CD工具链(七)使用Jmeter进行自动化压测

    上一篇文章中,我们详细介绍了构建 Apifox Cli 的 Docker 镜像的步骤,并通过简单的示例演示了如何利用 GitLab 的 CI/CD 功能,将构建好的镜像利用在自动化测试作业中。在今天的文章中,我们将重点讨论如何构建 JMeter 的 Docker 镜像,并演示如何在 GitLab 的 CI/CD 作业中利用该镜像

    2024年04月16日
    浏览(2)
  • 【Kubernetes 企业项目实战】06、基于 Jenkins+K8s 构建 DevOps 自动化运维管理平台(中)

    目录 一、基于 Jenkins+k8s+Git+Docker Hub 等技术链构建企业级 DevOps 容器云平台 1.1 安装 Jenkins 1.1.1 安装 nfs 服务 1.1.2 在 kubernetes 中部署 jenkins 1.2 配置 Jenkins ​1.2.1 获取管理员密码 1.2.2 安装插件 1.2.3 创建第一个管理员用户 1.3 测试 jenkins 的 CI/CD 1.3.1 在 Jenkins 中安装 kubernetes 插件

    2024年01月16日
    浏览(20)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包