Un total de 3 bibliothèques Python sont nécessaires ici, à savoir os, pandas et moviepy.
① os : utilisé pour obtenir les fichiers et la taille des fichiers dans un certain répertoire ;
② pandas : utilisé pour enregistrer les informations extraites dans Excel
③ moviepy : utilisé pour obtenir la durée dans la vidéo ; file;
Remarque : pandas et moviepy sont des bibliothèques tierces, nous devons donc les installer à l'avance à l'aide de la commande suivante.
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
Les résultats sont les suivants :
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)}'
En raison de ce qui suit introductionVideoFileClip()
Méthode, l'unité pour obtenir la durée est la seconde. Par conséquent, les secondes doivent être converties au format « heures, minutes et secondes » approprié. Si le temps dépasse une minute, il est converti en « minutes : secondes » ; s'il dépasse une heure, il est converti au format « heures : minutes : secondes ».
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
Les résultats sont les suivants :
df.to_excel("info.xlsx",index=False)
L'effet final est tel que montré sur l'image :
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!