使用mediainfo工具統計每個視頻文件(媒體文件)播放時長
需求
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工具打開
這就是我們想要的內容了
使用mediainfo工具統計每個視頻文件(媒體文件)播放時長