Linux中ffmpeg批量压缩音频

这篇博客介绍了如何在Linux环境下利用ffmpeg工具批量压缩音频文件。首先,讲解了ffmpeg的安装过程,然后提供了一个示例代码,通过指定-b:a 128k参数来设定压缩比特率为128k。在实际操作中,将音乐文件夹中的所有.flac音频文件转换为.mp3格式,并利用-thread参数调整CPU线程。最后,提到了转换完成后如何清理源文件并重命名新文件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Linux中ffmpeg批量压缩音频

安装ffmpeg

sudo apt-get install ffmpeg

压缩音频代码

ffmpeg -i input.mp3 -codec:a libmp3lame -b:a 128k output.mp3

其中-b:a 128k 表示恒定压缩比特率为128k

示例

现在有一个music文件夹,里面有10首格式为.flac的音频文件

批量处理

for file in *.flac; do ffmpeg -threads 16 -i "$file" -codec:a libmp3lame -b:a 128k "
下面是一个使用 Unix Domain Socket 进行进程间通信的简单例子: 服务端代码: ```c #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <sys/socket.h> #include <sys/un.h> #define SOCKET_PATH "/tmp/mysocket" int main(void) { int server_fd, client_fd; struct sockaddr_un server_addr, client_addr; socklen_t client_len; // 创建 socket server_fd = socket(AF_UNIX, SOCK_STREAM, 0); if (server_fd == -1) { perror("socket"); exit(EXIT_FAILURE); } // 绑定地址 memset(&server_addr, 0, sizeof(server_addr)); server_addr.sun_family = AF_UNIX; strncpy(server_addr.sun_path, SOCKET_PATH, sizeof(server_addr.sun_path) - 1); unlink(SOCKET_PATH); if (bind(server_fd, (struct sockaddr *)&server_addr, sizeof(server_addr)) == -1) { perror("bind"); exit(EXIT_FAILURE); } // 监听端口 if (listen(server_fd, 5) == -1) { perror("listen"); exit(EXIT_FAILURE); } printf("Listening on socket %s\n", SOCKET_PATH); while (1) { // 接受连接 client_len = sizeof(client_addr); client_fd = accept(server_fd, (struct sockaddr *)&client_addr, &client_len); if (client_fd == -1) { perror("accept"); continue; } printf("Accepted connection\n"); // 发送欢迎消息 if (write(client_fd, "Welcome to my server", 21) == -1) { perror("write"); close(client_fd); continue; } // 关闭连接 close(client_fd); } return 0; } ``` 客户端代码: ```c #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <sys/socket.h> #include <sys/un.h> #define SOCKET_PATH "/tmp/mysocket" int main(void) { int server_fd; struct sockaddr_un server_addr; char buf[1024]; ssize_t n; // 创建 socket server_fd = socket(AF_UNIX, SOCK_STREAM, 0); if (server_fd == -1) { perror("socket"); exit(EXIT_FAILURE); } // 连接到服务端 memset(&server_addr, 0, sizeof(server_addr)); server_addr.sun_family = AF_UNIX; strncpy(server_addr.sun_path, SOCKET_PATH, sizeof(server_addr.sun_path) - 1); if (connect(server_fd, (struct sockaddr *)&server_addr, sizeof(server_addr)) == -1) { perror("connect"); exit(EXIT_FAILURE); } // 读取欢迎消息 n = read(server_fd, buf, sizeof(buf)); if (n == -1) { perror("read"); exit(EXIT_FAILURE); } printf("Received: %.*s\n", (int)n, buf); // 关闭连接 close(server_fd); return 0; } ``` 以上代码演示了一个简单的 Unix Domain Socket 客户端和服务端的通信过程。服务端创建了一个 Unix Domain Socket 并监听客户端的连接请求,客户端连接到服务端并发送一个请求,服务端收到请求后向客户端发送一个欢迎消息,然后关闭连接。通信过程中使用了 read 和 write 函数进行数据传输。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值