-
Notifications
You must be signed in to change notification settings - Fork 70
/
Copy pathsubtitler.py
123 lines (98 loc) · 4.22 KB
/
subtitler.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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
# Standard library imports
import os
import glob
import subprocess
import re
import datetime
import logging
# Third party imports
# Local application imports
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
def adjust_subtitle_timing(subtitle_path, output_path):
"""
Adjusts subtitle timings to start from the beginning of the video.
"""
with open(subtitle_path, 'r', encoding='utf-8') as file:
lines = file.readlines()
time_pattern = re.compile(r'(\d{2}:\d{2}:\d{2},\d{3})')
first_timestamp = None
for line in lines:
time_match = time_pattern.findall(line)
if time_match:
first_timestamp = datetime.datetime.strptime(time_match[0], '%H:%M:%S,%f')
break
if first_timestamp is None:
return # No adjustment needed if no timestamps found
start_delta = first_timestamp - datetime.datetime.strptime('00:00:00,000', '%H:%M:%S,%f')
with open(output_path, 'w', encoding='utf-8') as file:
for line in lines:
new_line = line
match = time_pattern.findall(line)
if match:
new_times = []
for time_str in match:
original_time = datetime.datetime.strptime(time_str, '%H:%M:%S,%f')
new_time = original_time - start_delta
new_times.append(new_time.strftime('%H:%M:%S,%f')[:-3])
new_line = time_pattern.sub(lambda x: new_times.pop(0), line)
file.write(new_line)
logging.info(f"Subtitles timings adjusted: {output_path}")
def convert_to_utf8(subtitle_path, output_path):
"""
Converts subtitle file encoding to UTF-8.
"""
try:
with open(subtitle_path, 'r', encoding='iso-8859-1') as file:
content = file.read()
with open(output_path, 'w', encoding='utf-8') as file:
file.write(content)
logging.info(f"Subtitle encoding converted: {output_path}")
except Exception as e:
logging.error(f"Error during subtitle conversion: {e}")
def burn_subtitles(video_path, subtitle_path, output_video_path):
"""
Uses ffmpeg to burn subtitles into the video.
"""
cmd = [
'ffmpeg',
'-i', video_path,
'-vf', f"subtitles={subtitle_path}",
'-c:a', 'copy',
output_video_path
]
try:
subprocess.run(cmd, check=True)
logging.info(f"Subtitles have been burned into the video: {output_video_path}")
except subprocess.CalledProcessError as e:
logging.error(f"Error burning subtitles: {e}")
def process_video_and_subtitles(video_path, subtitle_path, output_folder):
"""
Full processing of video and subtitles.
"""
if not os.path.exists(output_folder):
os.makedirs(output_folder)
base_name = os.path.splitext(os.path.basename(video_path))[0]
adjusted_subtitle_path = os.path.join(output_folder, base_name + '_adjusted.srt')
utf8_subtitle_path = os.path.join(output_folder, base_name + '_utf8.srt')
output_video_path = os.path.join(output_folder, base_name + '_subtitled.mp4')
adjust_subtitle_timing(subtitle_path, adjusted_subtitle_path)
convert_to_utf8(adjusted_subtitle_path, utf8_subtitle_path)
burn_subtitles(video_path, utf8_subtitle_path, output_video_path)
os.remove(adjusted_subtitle_path)
os.remove(utf8_subtitle_path)
logging.info("Temporary subtitle files removed.")
if __name__ == "__main__":
trimmed_videos = glob.glob('clipper_output/*_trimmed.mp4')
subtitle_files = glob.glob('crew_output/*.srt')
output_folder = "subtitler_output" # Ensure this is correctly set
# Check if output_folder exists, create it if not
if not os.path.exists(output_folder):
os.makedirs(output_folder)
subtitle_dict = {os.path.splitext(os.path.basename(s))[0]: s for s in subtitle_files}
for trimmed_video in trimmed_videos:
base_name = os.path.splitext(os.path.basename(trimmed_video))[0].replace('_trimmed', '')
subtitle_file = subtitle_dict.get(base_name)
if subtitle_file:
process_video_and_subtitles(trimmed_video, subtitle_file, output_folder)
else:
logging.error(f"Subtitle file not found for {trimmed_video}")