文章目录
一、工具简介
这些工具都是与多媒体处理和流媒体相关的开源工具,它们都属于 FFmpeg 多媒体框架。
- FFmpeg
是一个用于处理多媒体内容(音频、视频、图像等)的命令行工具。它可以执行各种各样的操作,包括转码、剪辑、合并、分离、编码、解码等。FFmpeg 是一个功能强大且广泛使用的工具,可以在多种平台上运行。
- FFplay
是 FFmpeg 提供的一个简单的媒体播放器,它可以播放各种格式的音频和视频文件。FFplay 是基于 FFmpeg 库构建的,它提供了一个轻量级的命令行界面,可用于快速播放多媒体文件,适用于测试和简单的播放任务。
- FFprobe
是一个用于分析多媒体文件的工具。它提供了详细的信息,包括多媒体文件的编解码器、格式、流信息等。FFprobe 可以帮助用户了解多媒体文件的特性,例如分辨率、帧率、比特率等,这对于诊断和处理多媒体文件非常有用。
- FFserver
是一个流媒体服务器,可以用于实时转码和分发音频/视频流。它可以接受来自各种来源(如摄像头、音频接口等)的多媒体流,并将其转码为不同的格式和分辨率,然后通过网络分发给客户端。FFserver 可以用于构建自己的流媒体平台,例如音视频直播服务或视频点播服务。
二、使用golang获取时间长
package main
import (
"bufio"
"fmt"
"os/exec"
"strconv"
)
// getDuration 通过调用 ffprobe 来获取音视频文件的时长
// 函数接收一个字符串参数 filePath,表示音视频文件的路径。
// 函数返回两个值:一个整数表示时长(秒),一个 error 表示可能发生的错误。
func getDuration(filePath string) (int, error) {
// 使用 exec.Command 创建一个新的命令,调用 ffprobe 并带上一系列参数来指示它只输出文件的时长。
cmd := exec.Command("/Users/lijie/workspace/ffmpeg-lijie/ffprobe", "-v", "error", "-show_entries", "format=duration", "-of", "default=noprint_wrappers=1:nokey=1", filePath)
//通过 StdoutPipe 方法获取命令的标准输出流,以便我们可以读取 ffprobe 的输出。
stdout, err := cmd.StdoutPipe()
//如果在获取输出流时发生错误,则返回错误。
if err != nil {
return 0, err
}
//启动 ffprobe 命令。如果启动失败,则返回错误。
if err := cmd.Start(); err != nil {
return 0, err
}
//创建一个新的 bufio.Scanner 来读取 ffprobe 的标准输出。
scanner := bufio.NewScanner(stdout)
//使用 Scan 方法读取输出的第一行(即文件的时长)。
if scanner.Scan() {
//scanner.Text() 获取读取到的字符串。
durationStr := scanner.Text()
//使用 strconv.ParseFloat 将时长字符串转换为浮点数。
duration, err := strconv.ParseFloat(durationStr, 64)
//如果转换失败,则返回错误。
if err != nil {
return 0, err
}
//将浮点数时长转换为整数(秒),并返回,没有错误。
return int(duration), nil
}
return 0, fmt.Errorf("no duration found")
}
// formatDurationSeconds 函数将秒数转换为分秒格式的字符串。
// 函数接收一个整数参数 seconds,表示时长(秒)。
// 函数返回一个字符串,表示时分秒格式的时长。
func formatDurationSeconds(seconds int) string {
//计算时钟数,通过将总秒数除以3600。
hours := seconds / 3600
//计算分钟数,通过将总秒数除以60。
minutes := (seconds % 3600) / 60
//计算剩余的秒数,通过取总秒数除以60的余数。
seconds = seconds % 60
//根据秒数自动判断是否包含小时,并相应地格式化输出
if hours > 0 {
//根据秒数自动判断是否包含分钟,并相应地格式化输出
if minutes > 0 {
//使用 fmt.Sprintf 格式化分钟和秒数为 "MM:SS" 格式的字符串,并确保分钟和秒数都是两位数(不足两位时前面补0)。
return fmt.Sprintf("%02d:%02d:%02d", hours, minutes, seconds)
} else {
return fmt.Sprintf("%02d:%02d", hours, seconds)
}
} else if minutes > 0 {
return fmt.Sprintf("%02d:%02d", minutes, seconds)
} else {
return fmt.Sprintf("00:%02d", seconds)
}
}
func main() {
//定义音视频文件的路径,并替换为实际的文件路径。
filePath := "/opt/www/nginx/html/pages/resource/input.mp3"
//调用 getDuration 函数获取文件的时长(秒)。
durationSeconds, err := getDuration(filePath)
//如果在获取时长时发生错误,则打印错误并退出程序。
if err != nil {
fmt.Println("Error getting duration:", err)
return
}
fmt.Println("Duration:", durationSeconds)
//调用 formatDurationSeconds 函数将时长(秒)转换为时分秒格式的字符串。
durationFormatted := formatDurationSeconds(durationSeconds)
fmt.Printf("Duration: %s\n", durationFormatted)
}