詳解Python如何獲取視頻文件的大小和時(shí)長
前段時(shí)間,微信群有一個(gè)朋友問了下面這個(gè)問題,雖然很簡單,但是覺得有必要和大家做一個(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è)簡單的web登錄頁面
這篇文章主要給大家介紹了關(guān)于如何利用django和mysql實(shí)現(xiàn)一個(gè)簡單的web登錄頁面的相關(guān)資料,文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-05-05
python 求10個(gè)數(shù)的平均數(shù)實(shí)例
今天小編就為大家分享一篇python 求10個(gè)數(shù)的平均數(shù)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12
python和pyqt實(shí)現(xiàn)360的CLable控件
這篇文章主要介紹了python和pyqt實(shí)現(xiàn)360的CLable控件示例,需要的朋友可以參考下2014-02-02
python3調(diào)用ansible?api使用實(shí)例例說明
這篇文章主要為大家介紹了python3?調(diào)用ansible?api使用說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07

