FFmpeg - это немного приключение для разбора.Но в любом случае вот что вам нужно знать.
Во-первых, FFmpeg не очень хорошо работает с опциями RedirectOutput
Вместо этого вам нужно будет сделать следующее:непосредственного запуска ffmpeg, запуска cmd.exe
, передачи ffmpeg в качестве аргумента и перенаправления вывода в «файл монитора» через вывод командной строки, например так ... обратите внимание, что в цикле while (!proc.HasExited)
вы можете прочитать этот файлдля статуса FFmpeg в реальном времени или просто прочитайте его в конце, если это быстрая операция.
FileInfo monitorFile = new FileInfo(Path.Combine(ffMpegExe.Directory.FullName, "FFMpegMonitor_" + Guid.NewGuid().ToString() + ".txt"));
string ffmpegpath = Environment.SystemDirectory + "\\cmd.exe";
string ffmpegargs = "/C " + ffMpegExe.FullName + " " + encodeArgs + " 2>" + monitorFile.FullName;
string fullTestCmd = ffmpegpath + " " + ffmpegargs;
ProcessStartInfo psi = new ProcessStartInfo(ffmpegpath, ffmpegargs);
psi.WorkingDirectory = ffMpegExe.Directory.FullName;
psi.CreateNoWindow = true;
psi.UseShellExecute = false;
psi.Verb = "runas";
var proc = Process.Start(psi);
while (!proc.HasExited)
{
System.Threading.Thread.Sleep(1000);
}
string encodeLog = System.IO.File.ReadAllText(monitorFile.FullName);
Отлично, теперь у вас есть журнал того, что FFmpeg просто выплюнул.Теперь, чтобы получить продолжительность. Строка продолжительности будет выглядеть примерно так:
Duration: 00:10:53.79, start: 0.000000, bitrate: 9963 kb/s
Очистите результаты в List<string>
:
var encodingLines = encodeLog.Split(System.Environment.NewLine[0]).Where(line => string.IsNullOrWhiteSpace(line) == false && string.IsNullOrEmpty(line.Trim()) == false).Select(s => s.Trim()).ToList();
... затем просматривайте их в поисках Duration
.
foreach (var line in encodingLines)
{
// Duration: 00:10:53.79, start: 0.000000, bitrate: 9963 kb/s
if (line.StartsWith("Duration"))
{
var duration = ParseDurationLine(line);
}
}
Вот код, который может выполнить анализ для вас:
private TimeSpan ParseDurationLine(string line)
{
var itemsOfData = line.Split(" "[0], "="[0]).Where(s => string.IsNullOrEmpty(s) == false).Select(s => s.Trim().Replace("=", string.Empty).Replace(",", string.Empty)).ToList();
string duration = GetValueFromItemData(itemsOfData, "Duration:");
return TimeSpan.Parse(duration);
}
private string GetValueFromItemData(List<string> items, string targetKey)
{
var key = items.FirstOrDefault(i => i.ToUpper() == targetKey.ToUpper());
if (key == null) { return null; }
var idx = items.IndexOf(key);
var valueIdx = idx + 1;
if (valueIdx >= items.Count)
{
return null;
}
return items[valueIdx];
}