1. 前置知识这里一共需要用到3个python库,分别是os、pandas、moviepy。
① os:用于获取某个目录下的文件和文件大小;
② pandas:用于将提取到的信息,保存到excel中;
③ moviepy:用于获取视频文件中的时长;
注意:pandas和moviepy属于第三方库,因此需要我们提前使用如下命令进行安装。
pip install pandaspip install moviepy
2. 完整代码① 导入所有库import osimport pandas as pdfrom moviepy.editor import videofileclip
② 获取指定目录下符合条件的文件useful_dir = []for i in os.listdir(): if i.endswith("wmv"): useful_dir.append(i)useful_dir
结果如下:
③ 自定义时间转化函数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()方法,获取时长的单位是秒。因此,需将秒换成合适的"时分秒"格式。若时间超过一分钟,换算成"分钟:秒",若超过一小时,就换算成"小时:分钟:秒"格式。
④ 获取文件大小和时长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,"文件时长":y})df
结果如下:
⑤ 将得到的数据存储到excel中df.to_excel("info.xlsx",index=false)
最终效果如图所示:
以上就是python如何获取视频文件的大小和时长?的详细内容。