-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathpreview.py
92 lines (71 loc) · 3.72 KB
/
preview.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
import os
from termcolor import colored
from progress.bar import IncrementalBar
import utils.commander as commander
import utils.ffmpeg as ffmpeg
import utils.glob as glob
import utils.utils as utils
import tempfile
def process_previews(args, video_files):
temp_folder_path = glob.join_path(tempfile.gettempdir(), "preview-temp")
glob.delete_folder(temp_folder_path)
glob.create_folder(temp_folder_path)
if not args.samepath:
glob.create_folder(args.out)
is_invalid_duration = False
if len(video_files):
for index, video_file in enumerate(video_files):
file_name = glob.get_file_name(video_file)
file_extension = glob.get_file_name(video_file, "ext")
relative_path = f"{file_name}.{file_extension}" if os.path.relpath(video_file, args.path) == "." else os.path.relpath(video_file, args.path)
video_duration = ffmpeg.get_video_duration(video_file)
expected_preview_duration = round(args.segments * args.sduration)
if expected_preview_duration < round(video_duration):
ratio = round(video_duration / args.segments, 3)
temp_file_contents = ""
video_segment_prog = IncrementalBar(utils.wrap_text(relative_path), max=round(args.segments) + 1, suffix="%(percent)d%%")
count = 0
v_bitrate = ffmpeg.get_video_bitrate(video_file)
a_bitrate = ffmpeg.get_audio_bitrate(video_file)
while count < round(args.segments):
if count == 0:
video_segment_prog.update() # prints the progress bar even before finishing this loop event
start_time = args.skip if count == 0 else round(count * ratio, 3)
ffmpeg.generate_preview_chunck(video_file, start_time, v_bitrate, a_bitrate, args, temp_folder_path, f"{index}-{count}")
temp_file_contents += f"file '{index}-{count}.mp4'\n"
video_segment_prog.next()
count += 1
temp_file_path = glob.join_path(temp_folder_path, f"{index}.txt")
with open(temp_file_path, "w") as file:
file.write(temp_file_contents)
if args.samepath:
out = glob.join_path(glob.get_dirname(video_file), args.out)
else:
out = args.out
glob.create_folder(out)
ffmpeg.generate_preview(temp_file_path, glob.join_path(out, f"{file_name} preview"), args)
video_segment_prog.next()
video_segment_prog.finish()
else:
if video_duration > 0:
print(colored(f"skipped [Invalid duration ({round(video_duration)}:{expected_preview_duration})]: ", "yellow"), relative_path)
else:
print(colored("skipped [Unavailable duration]", "yellow"), relative_path)
is_invalid_duration = True
else:
print(colored("No videos found in the specified folder", "red"))
if is_invalid_duration:
print()
print(colored("Warning codes:", "yellow"))
print(colored(" 1. Unavailable duration: Can't fetch the video duration", "yellow"))
print(colored(" 2. Invalid duration (video duration:expected preview duration): Estimated preview video is equal or longer than the actual video", "yellow"))
glob.delete_folder(temp_folder_path)
if __name__ == "__main__":
args = commander.init()
commander.log_args(args)
video_files = glob.get_all_video_files(args.path)
if video_files == False:
commander.exit_program()
else:
process_previews(args, video_files)
commander.exit_program()