想听的音乐没有版权?没关系,ffmpeg帮你解决🐒🐒🐒

听音乐你喜欢听吧?一些喜欢的歌曲突然就没有版权了或者被下架的情况屡见不鲜。

例如我要听一首天梯,我从酷狗和网易云上面都搜不到:

搜到的都是翻唱的,不过还好我云盘上存有,还可以勉强听一下。

遇到这种情况,我们也就只有去 b 站或者 YouTube 上听了,但是麻烦呀,总不会要每次一首一首地搜吧?

别担心,我们可以使用 ffmpeg 来解决这个问题。

ffmpeg 是什么

FFmpeg 是领先的多媒体框架,能够解码、编码、转码、复用、分离、流式传输、过滤和播放几乎所有人类和机器创造的内容。它支持从最古老的格式到最前沿的技术。无论这些格式是由某些标准委员会、社区还是公司设计的。它还具有极高的可移植性:FFmpeg 能够在 Linux、Mac OS X、Microsoft Windows、BSDs、Solaris 等操作系统上编译、运行,并在我们的测试基础设施 FATE 上通过测试,适应各种构建环境、机器架构和配置。

ffmpeg 实现音视频编码

首先我们先来一个简答的案例来实现这个破需求,这个时候我们需要一个 MP4 文件,你可以从 b 站和 YouTube 上下载下来,至于你会不会下载那就是另一回事了。

初始化一个 node 项目并且终端安装 fluent-ffmpeg:

bash 复制代码
pnpm add fluent-ffmpeg

安装完成之后,并编写一下代码:

js 复制代码
const ffmpeg = require("fluent-ffmpeg");

function convertMp4ToMp3(inputPath, outputPath) {
  return new Promise((resolve, reject) => {
    ffmpeg(inputPath)
      .output(outputPath)
      .audioCodec("libmp3lame") // 使用 MP3 编解码器
      .on("end", () => {
        console.log("转换完成");
        resolve();
      })
      .on("error", (err) => {
        console.error("转换错误:", err);
        reject(err);
      })
      .run();
  });
}

const inputVideoPath = "./source/天梯.mp4"; // MP4 文件路径
const outputAudioPath = "./output/天梯.mp3"; // 输出 MP3 文件路径

convertMp4ToMp3(inputVideoPath, outputAudioPath)
  .then(() => console.log("MP4 转 MP3 成功"))
  .catch((err) => console.error("MP4 转 MP3 失败:", err));

在上面的这段代码中,主要使用了 fluent-ffmpeg 库将 MP4 文件转换为 MP3 文件。通过使用 libmp3lame 编码器编解码转换音频,然后将结果保存为 MP3 文件。

如上图所示,最终转换成功。

总结

通过 ffmpeg 将视频转换为音频的方式我们得到了 MP3 文件,我们可以把这些文件存放于固定的播放位置或者自己写一个软件的 app,这样就可以听到所有的已经被下架了的歌,甚至还可以把冲会员的钱都省下来了。

吐槽两句,要想 ffmpeg 还是要学 Python 或者 c/c 艹,不然很多功能单纯用 node 都无法实现。

相关推荐
火星校尉13 小时前
一场数据基建与消费场景的跨界实验
java·前端·数据库·python·php
risc12345614 小时前
Lucene80DocValuesConsumer 五种类型源码阅读顺序
java·服务器·前端
小米渣的逆袭14 小时前
Chrome Extension Script World(ISOLATED / MAIN)原理与适用场景
前端·javascript·chrome
雨师@14 小时前
go语言项目--实例化(图书管理)--005
开发语言·后端·golang
微信开发api-视频号协议14 小时前
Codex++安全边界探秘:从模型能力到风险防御
前端·安全·微信·企业微信
Aspiresky14 小时前
探索Rust语言之引用
开发语言·后端·rust
想你依然心痛14 小时前
AtomCode 在前端开发中的实战体验:React + TypeScript 项目开发实录
前端·react.js·typescript
冰暮流星15 小时前
flask之app.py讲解
后端·python·flask
疯狂的魔鬼15 小时前
精确计算容器剩余视口高度:useAutoContainerFullHeight 的工程实践
前端·css·typescript
用户0595401744615 小时前
用了 3 个月 ChatGPT,才发现它一直在遗忘——用 Playwright 自动化验证记忆存储一致性
前端·css