詳解Python如何獲取視頻文件的大小和時(shí)長
前段時(shí)間,微信群有一個(gè)朋友問了下面這個(gè)問題,雖然很簡(jiǎn)單,但是覺得有必要和大家做一個(gè)知識(shí)分享。
這個(gè)問題一共有兩個(gè)需求:
- ① 獲取視頻的文件大??;
- ② 獲取視頻的時(shí)長;
基于上述兩個(gè)問題,我來教大家如何將獲取到的信息存儲(chǔ)到Excel中。
1. 前置知識(shí)
這里一共需要用到3個(gè)Python庫,分別是os、pandas、moviepy。
- ① os:用于獲取某個(gè)目錄下的文件和文件大?。?/li>
- ② pandas:用于將提取到的信息,保存到Excel中;
- ③ moviepy:用于獲取視頻文件中的時(shí)長;
注意:pandas和moviepy屬于第三方庫,因此需要我們提前使用如下命令進(jìn)行安裝。
pip install pandas pip install moviepy
2. 完整代碼
① 導(dǎo)入所有庫
import os import pandas as pd from moviepy.editor import VideoFileClip
② 獲取指定目錄下符合條件的文件
useful_dir = [] for i in os.listdir(): if i.endswith("wmv"): useful_dir.append(i) useful_dir
結(jié)果如下:
③ 自定義時(shí)間轉(zhuǎn)化函數(shù)
def time_convert(seconds): M,H = 60,3600 if seconds < M: return f'00:00:0{seconds}' if seconds < 10 else f'00:00:{str(seconds)}' elif seconds < H: _M = int(seconds//M) _S = int(seconds%M) return f'00:{f"0{_M}" if _M < 10 else str(_M)}:{f"0{_S}" if _S < 10 else str(_S)}' else: _H = int(seconds//H) _M = int(seconds%H//M) _S = int(seconds%H%M) return f'{f"0{_H}" if _H < 10 else str(_H)}:{f"0{_M}" if _M < 10 else str(_M)}:{f"0{_S}" if _S < 10 else str(_S)}'
由于下面介紹的VideoFileClip()
方法,獲取時(shí)長的單位是秒。因此,需將秒換成合適的"時(shí)分秒"格式。若時(shí)間超過一分鐘,換算成"分鐘:秒",若超過一小時(shí),就換算成"小時(shí):分鐘:秒"格式。
④ 獲取文件大小和時(shí)長
x = [] y = [] for i in useful_dir: dir_size = str(round(os.path.getsize(i)/1024/1024,1)) + "M" clip = VideoFileClip(i) dir_time = time_convert(clip.duration) x.append(dir_size) y.append(dir_time) df = pd.DataFrame({"文件大小":x,"文件時(shí)長":y}) df
結(jié)果如下:
⑤ 將得到的數(shù)據(jù)存儲(chǔ)到Excel中
df.to_excel("info.xlsx",index=False)
最終效果如圖所示:
到此這篇關(guān)于詳解Python如何獲取視頻文件的大小和時(shí)長的文章就介紹到這了,更多相關(guān)Python獲取視頻大小時(shí)長內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python之yield表達(dá)式學(xué)習(xí)
這篇文章主要介紹了python之yield表達(dá)式學(xué)習(xí),python中有一個(gè)略微奇怪的表達(dá)式叫yield expression,本文就來探究一下這是個(gè)什么東西,需要的朋友可以參考下2014-09-09利用django和mysql實(shí)現(xiàn)一個(gè)簡(jiǎn)單的web登錄頁面
這篇文章主要給大家介紹了關(guān)于如何利用django和mysql實(shí)現(xiàn)一個(gè)簡(jiǎn)單的web登錄頁面的相關(guān)資料,文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-05-05python 求10個(gè)數(shù)的平均數(shù)實(shí)例
今天小編就為大家分享一篇python 求10個(gè)數(shù)的平均數(shù)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12python和pyqt實(shí)現(xiàn)360的CLable控件
這篇文章主要介紹了python和pyqt實(shí)現(xiàn)360的CLable控件示例,需要的朋友可以參考下2014-02-02python3調(diào)用ansible?api使用實(shí)例例說明
這篇文章主要為大家介紹了python3?調(diào)用ansible?api使用說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07