1. 程式人生 > >使用mediainfo工具統計每個視頻文件(媒體文件)播放時長

使用mediainfo工具統計每個視頻文件(媒體文件)播放時長

安裝 測試 桌面 參數 獲取 txt [ ] 記錄 可能

需求

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工具統計每個視頻文件(媒體文件)播放時長