gpt4 book ai didi

python - 将数据附加到波形声音文件而不加载其当前内容

转载 作者:太空宇宙 更新时间:2023-11-03 11:37:33 26 4
gpt4 key购买 nike

我正在尝试将数据附加到声音文件而不加载其内容(因为它可能有千兆字节的数据),我目前正在使用 pysoundfile 库,我已经找到了一种方法来为 wave64 做这件事,但是在 wav 中,由于某种原因它会抛出错误。

根据 pysoundfile 文档,当使用文件描述符打开 SoundFile 时,它​​应该在不截断的情况下写入,这就是我目前正在做的事情

    fd = open('foo.wav',mode='ab')
with sf.SoundFile(fd, mode = 'w', samplerate = self._samplerate,channels = self._channels, format = 'wav') as wfile:
wfile.seek(0,sf.SEEK_END)
wfile.write(self._samples)
wfile.close()
fd.close()

当我使用 wave 文件类型时,出现以下错误:

RuntimeError: Error opening <_io.BufferedWriter name='../datasets/emddf_clean/qcoisa.wav'>: Unspecified internal error.

但是对于以 w64 格式格式化的文件,它以某种方式工作......如果有人能对我有所启发,那将是惊人的,提前致谢!

最佳答案

我成功地做了我想做的,没有显式地使用文件描述符:

    with sf.SoundFile(path['full_path'], mode = 'r+') as wfile:
wfile.seek(0,sf.SEEK_END)
wfile.write(self._samples)

如果文件处于r+模式(读/写),它支持查找,这意味着我们可以指向文件的末尾允许追加。唯一的问题是,如果该文件不存在,它会抛出一个错误,但您可以通过执行以下操作轻松修复它:

    if(self.mode == my_utils.APPEND and os.path.isfile(path['full_path'])):
with sf.SoundFile(path['full_path'], mode = 'r+', samplerate = samplerate) as wfile:
wfile.seek(0,sf.SEEK_END)
wfile.write(self.file.getSamples())
else:
sf.write(path['full_path'], self.file.getSamples(), samplerate,format=path['extension']) # writes to the new file
return

希望我说清楚并帮助别人!

关于python - 将数据附加到波形声音文件而不加载其当前内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56058997/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com