gpt4 book ai didi

python - 如何在一条消息中为kafka生成音频(.wav)

转载 作者:行者123 更新时间:2023-11-28 17:55:34 26 4
gpt4 key购买 nike

为了使用大数据技术应用实时语音分析,我尝试在开始时使用 KAFKA。因此,首先我使用 WAVIO API 将 .wav 文件转换为字节,然后将包含 [data(nparray 的类型)、rate (integer) 和 sampwidth (integer)] 的消息发送到 kafka,在这些消息将被消费者消费后,他们将转换将它们再次写入 .wav 文件。

问题是我如何在一条消息中向 kafka 发送和接收这些 [data, rate, sampwidth](每条消息代表 .wav 文件)?

对于制作人:

    producer = KafkaProducer(bootstrap_servers='localhost:9092')
x = wav2bytes("bush_read") # return tuple containing(data, rate, sampwidth)
#here I'm sending 3 messages
producer.send("TestTopic", key=b'data', value=b'%s' % (x[0])) # data -> nparray
producer.send("TestTopic", key=b'rate', value=b'%d' % (x[1])) # rate -> int
producer.send("TestTopic", key=b'sampwidth', value=b'%d' % (x[2])) #sampwidth -> int
send("TestTopic","bush_read")

对于消费者:

    for message in consumer:
msg = message # I want somthing like this
file = bytes2wav("name", msg.data, msg.rate, msg.sampwidth )

最佳答案

如果需要,您可以将其作为 json(或任何其他序列化)发送,创建一个类似的 json

{'data':数据,'rate':速率,'sampwidth':sampwidth}

你可以在消费者中反序列化它

关于python - 如何在一条消息中为kafka生成音频(.wav),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58672013/

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