Python 官方文档:入门教程 => 点击学习
目录1. 前置知识2. 完整代码① 导入所有库② 获取指定目录下符合条件的文件③ 自定义时间转化函数④ 获取文件大小和时长⑤ 将得到的数据存储到excel中前段时间,微信群有一个朋友
前段时间,微信群有一个朋友问了下面这个问题,虽然很简单,但是觉得有必要和大家做一个知识分享。
这个问题一共有两个需求:
基于上述两个问题,我来教大家如何将获取到的信息存储到Excel中。
这里一共需要用到3个python库,分别是os、pandas、moviepy。
注意:pandas和moviepy属于第三方库,因此需要我们提前使用如下命令进行安装。
pip install pandas
pip install moviepy
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
结果如下:
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
结果如下:
df.to_excel("info.xlsx",index=False)
最终效果如图所示:
到此这篇关于详解Python如何获取视频文件的大小和时长的文章就介绍到这了,更多相关Python获取视频大小时长内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: 详解Python如何获取视频文件的大小和时长
本文链接: https://www.lsjlt.com/news/202653.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0