我需要在特定时间以特定持续时间将音频应用于视频,但某些音频持续时间比需要的更长(或更短)。如何在不改变音高的情况下改变音频的速度?我尝试更改 fps(通过将所需持续时间乘以除以音频持续时间)但它无法正常工作。
original = VideoFileClip("orig.mp4")
clips = [orig.audio.volumex(0.3)]
subs = [] #some array
i = 0
for sub in subs:
clip = AudioFileClip("\\temp{}.mp3")
mult = clip.duration / (sub.end - sub.start) + 0.00001
clip = AudioArrayClip(clip.to_soundarray(buffersize=500, fps=24000/mult), fps=24000).set_start(sub.start).set_end(sub.end)
clips.append(clip)
i += 1
final = CompositeAudioClip(clips)
final.write_audiofile("final.mp3")
最佳答案
你可以使用 librosa 模块:
from scipy.io import wavfile
import librosa, numpy as np
song, fs = librosa.load("song.wav")
song_2_times_faster = librosa.effects.time_stretch(song, 2)
scipy.io.wavfile.write("song_2_times_faster.wav", fs, song_2_times_faster) # save the song
关于python - 如何在不改变音高的情况下改变音频速度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41397111/