如何将一个 .wav 文件拆分成多个 .wav 文件?

46

我有一个几分钟长的.wav文件,我想将其分割成不同的10秒.wav文件。

以下是我目前的Python代码:

import wave
import math

def main(filename, time):
    read = wave.open(filename, 'r')

#get sample rate
    frameRate = read.getframerate()

#get number of frames
    numFrames = read.getnframes()

#get duration
    duration = numFrames/frameRate

#get all frames as a string of bytes
    frames = read.readframes(numFrames)

#get 1 frame as a string of bytes
    oneFrame = read.readframes(1)

#framerate*time == numframesneeded
    numFramesNeeded=frameRate*time

#numFramesNeeded*oneFrame=numBytes
    numBytes = numFramesNeeded*oneFrame

#splice frames to get a list strings each representing a 'time' length
#wav file
    x=0
    wavList=[]
    while x+time<=duration:
        curFrame= frames[x:x+time]
        x=x+time
        wavList.append(curFrame)

打印wavList得到:

['\x00\x00\x00\x00\xff\xff\x00\x00\x00\x00', '\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00', '\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00', '\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00', '\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00']

我知道这是一个帧列表。如何为列表中的每个元素创建一个.wav文件(第一个.wav文件将是'\x00\x00\x00\x00\xff\xff\x00\x00\x00\x00')?Python的wave模块使用帧来创建.wav文件不太清楚。

编辑:这是如何在python中将音频文件(wav格式)拼接成1秒片段的重复问题?如果有人有不需要pydub的答案,我非常希望看到它。


pydub 显然是完成此任务的简单方法。我认为你真正想要的是代码审查。如果你询问如何在更低的级别上执行此操作,为什么不直接阅读 pydub 代码呢?例如,请参见 get_sample_slice 和一般的 ._data 操作。 - Nikana Reklawyks
3个回答

73

以下是我用来根据需要分割文件的Python代码片段。
我使用pydub库,该库来自https://github.com/jiaaro/pydub。 您可以修改代码片段以满足您的需求。

from pydub import AudioSegment
t1 = t1 * 1000 #Works in milliseconds
t2 = t2 * 1000
newAudio = AudioSegment.from_wav("oldSong.wav")
newAudio = newAudio[t1:t2]
newAudio.export('newSong.wav', format="wav") #Exports to a wav file in the current path.

24

我写了一个类来简化整个过程。虽然它是为wavwbr>文件设计的。

这就是它:

from pydub import AudioSegment
import math

class SplitWavAudioMubin():
    def __init__(self, folder, filename):
        self.folder = folder
        self.filename = filename
        self.filepath = folder + '\\' + filename
        
        self.audio = AudioSegment.from_wav(self.filepath)
    
    def get_duration(self):
        return self.audio.duration_seconds
    
    def single_split(self, from_min, to_min, split_filename):
        t1 = from_min * 60 * 1000
        t2 = to_min * 60 * 1000
        split_audio = self.audio[t1:t2]
        split_audio.export(self.folder + '\\' + split_filename, format="wav")
        
    def multiple_split(self, min_per_split):
        total_mins = math.ceil(self.get_duration() / 60)
        for i in range(0, total_mins, min_per_split):
            split_fn = str(i) + '_' + self.filename
            self.single_split(i, i+min_per_split, split_fn)
            print(str(i) + ' Done')
            if i == total_mins - min_per_split:
                print('All splited successfully')

用法

folder = 'F:\\My Audios\\Khaled'
file = 'Khaled Speech.wav'
split_wav = SplitWavAudioMubin(folder, file)
split_wav.multiple_split(min_per_split=1)

就是这样!它将把单个wav文件分割成多个wav文件,每个文件持续时间为1分钟。 最后一个分割的音频可能不到1分钟的时间;)

注意:如果您使用Mac / Linux,则将\\更改为/


8

对于那些仅寻求有关wave模块答案的人。

import wave

# times between which to extract the wave from
start = 5.2 # seconds
end = 78.3 # seconds

# file to extract the snippet from
with wave.open('my_in_file.wav', "rb") as infile:
    # get file data
    nchannels = infile.getnchannels()
    sampwidth = infile.getsampwidth()
    framerate = infile.getframerate()
    # set position in wave to start of segment
    infile.setpos(int(start * framerate))
    # extract data
    data = infile.readframes(int((end - start) * framerate))

# write the extracted data to a new file
with wave.open('my_out_file.wav', 'w') as outfile:
    outfile.setnchannels(nchannels)
    outfile.setsampwidth(sampwidth)
    outfile.setframerate(framerate)
    outfile.setnframes(int(len(data) / sampwidth))
    outfile.writeframes(data)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接