3

我需要在特定时间以特定持续时间将音频应用于视频,但某些音频持续时间更大(或更小)然后需要。如何在不改变音高的情况下改变音频的速度?我试图改变 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")
4

2 回答 2

-1

你可以使用 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
于 2021-01-01T13:18:49.007 回答
-1

使用波形:改变采样率

import wave

CHANNELS = 1
swidth = 2
Change_RATE = 2

spf = wave.open('VOZ.wav', 'rb')
RATE=spf.getframerate()
signal = spf.readframes(-1)

wf = wave.open('changed.wav', 'wb')
wf.setnchannels(CHANNELS)
wf.setsampwidth(swidth)
wf.setframerate(RATE*Change_RATE)
wf.writeframes(signal)
wf.close()
于 2016-12-30T13:35:40.327 回答