gpt4 book ai didi

python - 如何将 base64 字符串直接解码为二进制音频格式

转载 作者:行者123 更新时间:2023-12-03 15:48:45 24 4
gpt4 key购买 nike

音频文件通过 API 发送给我们,API 是 Base64 编码的 PCM 格式。我需要将其转换为 PCM,然后再转换为 WAV 进行处理。

我能够解码 -> 保存到 pcm -> 从 pcm 读取 -> 使用以下代码保存为 wav。

decoded_data = base64.b64decode(data, ' /')
with open(pcmfile, 'wb') as pcm:
pcm.write(decoded_data)
with open(pcmfile, 'rb') as pcm:
pcmdata = pcm.read()
with wave.open(wavfile, 'wb') as wav:
wav.setparams((1, 2, 16000, 0, 'NONE', 'NONE'))
wav.writeframes(pcmdata)

如果我可以将输入字符串解码为二进制并另存为 wav,那就容易多了。所以我在 Convert string to binary in python 做了这样的事情
  decoded_data = base64.b64decode(data, ' /')
ba = ' '.join(format(x, 'b') for x in bytearray(decoded_data))
with wave.open(wavfile, 'wb') as wav:
wav.setparams((1, 2, 16000, 0, 'NONE', 'NONE'))
wav.writeframes(ba)

但我收到错误 a bytes-like object is required, not 'str'wav.writeframes .

也试过 base54.decodebytes()并得到同样的错误。

这样做的正确方法是什么?

最佳答案

我在我的一个项目中也遇到了类似的问题。

我能够将 base64 字符串直接转换为 wav :

import base64
encode_string = base64.b64encode(open("audio.wav", "rb").read())
wav_file = open("temp.wav", "wb")
decode_string = base64.b64decode(encode_string)
wav_file.write(decode_string)

首先将其编码为base64。然后创建一个 wav 格式的文件并将解码后的 base64 字符串写入该文件。

我知道这是一个很晚的答案。希望这可以帮助。

关于python - 如何将 base64 字符串直接解码为二进制音频格式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50279380/

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