需求
1、運營那邊需要統計大量視頻文件的播放時長,並匯總記錄到excel表中,問我有什么方法搞定
這邊搜索了很多統計媒體文件時長的,主要有以下幾種
1、使用java獲取
2、使用python獲取
3、使用mediainfo工具獲取
由於自己對java剛懂點基礎,要琢磨幾天才能寫出來,而python代碼下載的第三方模塊運行時總是報錯。一時半會無法解決
最終采用mediainfo工具
1、下載和安裝mediainfo工具
這邊下載使用的mediainfo工具是1.8版本的

2、簡單使用此工具查看一些媒體文件
在安裝目錄下找到此軟件入口(可以發送個快捷方式到桌面,方便以后使用)

可以打開文件或者文件夾

先查看一個電影文件。有一些輸出信息

點擊下面按鈕

可以看到一些定義好的輸出格式,選擇不同的格式,顯示的信息不一樣

這里選擇樹狀圖,可以看到很多信息

由於這里我只想要文件名和文件的播放時長,因此需要自定義輸出信息
選項--參數設置

找到自定義

點擊新建,自定義個名字,隨便定義

點擊OK之后彈出如下

保持第一行內容如下
General : %FileNameExtension%,%PlayTime/String1%
如下,點擊OK保存

保持當前自定義的是自己剛剛寫的

點擊確定
點擊左邊的查看方式

查看方式選擇自定義

可以看到輸出信息如下

可以看到第一行左邊是文件名,右邊是時間
其它信息是多出來的。我們沒配置,但是仍然默認多出來了。目前已經做到輸出信息最少了,同時我們需要的都在
如果不想看到毫秒等信息。可以編輯輸出的信息把string1改成string2

再次查看自定義信息,就沒有秒和毫秒了
經過我測試,如果文件沒超過一分鍾,會顯示為分鍾和秒
如果文件超過1小時,會顯示小時和分鍾。

3、使用mediainfo工具查看一批媒體文件
前提是媒體文件都在此文件夾下

視頻文件信息都出來了
如果文件比較多,可能要等一小會才會出現。我曾經統計過800個小視頻文件。軟件卡了5到10分鍾才顯示

4、對文件輸出信息進行處理加工
右鍵--全選

復制到一個文本里

復制到文本文件里

接下來就是對這些信息進行加工了。只保留文件名和時間
方式1
linux命令特別熟的可以選擇使用awk以及grep工具處理
grep General med.txt| awk -F ':[ ]' '{print $2}' |awk -F 'Video' '{print $1}'
上面是把信息放在了med.txt文件里的
先根據General過濾出文件名和時間這行,然后根據規律去掉文件名前面的字符串,然后去掉Video以及之后的字符串

方式2
使用windows版本的awk和grep工具
這里下載了awk工具和grep工具,都是windows版本的


這些命令工具都是從gnu網站下載的
http://gnuwin32.sourceforge.net/packages/gawk.htm
http://gnuwin32.sourceforge.net/packages/grep.htm
因為平時也用到了別的工具,自己都統一放在了下面目錄下,同時設置了環境變量,這樣就可以在任意目錄下使用了

很多windows版本的命令

添加工具目錄到環境變量里

添加個mypath
內容如下
C:\mytools\core\bin;C:\mytools\curl;C:\mytools\grep\bin;D:\autossh-cygwin;D:\sed-4.2.1-bin\bin;C:\mytools\gawk\bin
然后把mypath假如到系統的path里面

確定之后
進入工具目錄下,把mediainfo提取出的信息,保存到med.txt里面

創建個bat文件,里面內容如下
grep General med.txt| awk -F ":[ ]" "{print $2}" |awk -F "Video" "{print $1}" >2.csv

雙擊運行此bat文件,會出現一個2.csv文件。這就是處理后的文件,使用excel工具打開

這就是我們想要的內容了

