Update app.py
Browse files
app.py
CHANGED
@@ -611,35 +611,48 @@ def merge_videos_with_audio(video_files, audio_file, audio_volume, output_fps):
|
|
611 |
if audio_file:
|
612 |
status = "์ค๋์ค ์ฒ๋ฆฌ ์ค..."
|
613 |
|
614 |
-
|
615 |
-
|
616 |
-
|
617 |
-
|
618 |
-
|
619 |
-
|
620 |
-
|
621 |
-
|
622 |
-
|
623 |
-
|
624 |
-
|
625 |
-
|
626 |
-
|
627 |
-
|
628 |
-
|
629 |
-
|
630 |
-
|
631 |
-
|
632 |
-
|
633 |
-
|
634 |
-
|
635 |
-
|
636 |
-
|
637 |
-
|
638 |
-
|
639 |
-
|
640 |
-
|
641 |
-
|
642 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
643 |
|
644 |
status = "๋น๋์ค ์ ์ฅ ์ค..."
|
645 |
|
|
|
611 |
if audio_file:
|
612 |
status = "์ค๋์ค ์ฒ๋ฆฌ ์ค..."
|
613 |
|
614 |
+
try:
|
615 |
+
# ์ค๋์ค ๋ก๋
|
616 |
+
if audio_file.endswith(('.mp4', '.avi', '.mov', '.mkv')):
|
617 |
+
# ๋น๋์ค ํ์ผ์์ ์ค๋์ค ์ถ์ถ
|
618 |
+
temp_video = VideoFileClip(audio_file)
|
619 |
+
audio_clip = temp_video.audio
|
620 |
+
temp_video.close()
|
621 |
+
else:
|
622 |
+
# ์ค๋์ค ํ์ผ ์ง์ ๋ก๋
|
623 |
+
audio_clip = AudioFileClip(audio_file)
|
624 |
+
|
625 |
+
if audio_clip is None:
|
626 |
+
raise ValueError("์ค๋์ค๋ฅผ ๋ก๋ํ ์ ์์ต๋๋ค.")
|
627 |
+
|
628 |
+
# ๋ณผ๋ฅจ ์กฐ์
|
629 |
+
if audio_volume != 100:
|
630 |
+
audio_clip = audio_clip.volumex(audio_volume / 100)
|
631 |
+
|
632 |
+
# ์ค๋์ค๋ฅผ ๋น๋์ค ๊ธธ์ด์ ๋ง์ถค
|
633 |
+
video_duration = final_video.duration
|
634 |
+
audio_duration = audio_clip.duration
|
635 |
+
|
636 |
+
if audio_duration > video_duration:
|
637 |
+
# ์ค๋์ค๊ฐ ๋ ๊ธธ๋ฉด ์๋ผ๋
|
638 |
+
audio_clip = audio_clip.subclip(0, video_duration)
|
639 |
+
elif audio_duration < video_duration:
|
640 |
+
# ์ค๋์ค๊ฐ ๋ ์งง์ผ๋ฉด ๋ฐ๋ณต
|
641 |
+
loops_needed = int(video_duration / audio_duration) + 1
|
642 |
+
audio_clips_list = [audio_clip] * loops_needed
|
643 |
+
looped_audio = concatenate_audioclips(audio_clips_list)
|
644 |
+
audio_clip = looped_audio.subclip(0, video_duration)
|
645 |
+
|
646 |
+
# ๊ธฐ์กด ์ค๋์ค์ ์ ์ค๋์ค ํฉ์ฑ (๊ธฐ์กด ์ค๋์ค๊ฐ ์๋ ๊ฒฝ์ฐ)
|
647 |
+
if final_video.audio:
|
648 |
+
final_audio = CompositeAudioClip([final_video.audio, audio_clip])
|
649 |
+
final_video = final_video.set_audio(final_audio)
|
650 |
+
else:
|
651 |
+
final_video = final_video.set_audio(audio_clip)
|
652 |
+
|
653 |
+
except Exception as e:
|
654 |
+
logging.warning(f"์ค๋์ค ์ฒ๋ฆฌ ์ค ์ค๋ฅ ๋ฐ์: {str(e)}")
|
655 |
+
# ์ค๋์ค ์ฒ๋ฆฌ ์คํจํด๋ ๋น๋์ค๋ ๊ณ์ ์ฒ๋ฆฌ
|
656 |
|
657 |
status = "๋น๋์ค ์ ์ฅ ์ค..."
|
658 |
|