使用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工具打開

 

 這就是我們想要的內容了

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM