本文介绍了使用PyAudio进行流媒体播放时修改音量的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在尝试流式传输.WAV文件,同时去除其中一个声道,以便它只在一个扬声器上播放,同时降低音量。
我使用PyAudio的原因是我必须能够
- 一次传输多个文件
- 播放特定扬声器的声音(左/右)
- 中断播放声音文件
并且找不到允许这些功能的任何其他Python库。
我有以下代码,修改自PyAudio的流示例。它从一个扬声器播放WAV文件,但我无法找到以任何方式修改音量的方法。
"""PyAudio Example: Play a wave file."""
import pyaudio
import wave
import sys
CHUNK = 1024
if len(sys.argv) < 2:
print("Plays a wave file.
Usage: %s filename.wav" % sys.argv[0])
sys.exit(-1)
wf = wave.open(sys.argv[1], 'rb')
# instantiate PyAudio (1)
p = pyaudio.PyAudio()
# open stream (2)
sampwidth = wf.getsampwidth()
stream = p.open(format=p.get_format_from_width(sampwidth),
channels=wf.getnchannels(),
rate=wf.getframerate(),
output=True)
# read data
data = bytearray(wf.readframes(CHUNK))
# play stream (3)
while len(data) > 0:
#remove left channel
for i in range(0, len(data)):
if i % (sampwidth*2) < sampwidth:
data[i] = 0
#reduce volume by 50%
for i in range(0, len(data)):
# use magic???
pass
stream.write(bytes(data))
data = wf.readframes(CHUNK)
if len(data) > 0:
data = bytearray(data)
# stop stream (4)
stream.stop_stream()
stream.close()
# close PyAudio (5)
p.terminate()
如果有人能给我任何建议,我将不胜感激。我觉得答案需要比我目前拥有的更好地理解wav文件是如何格式化的。我尝试了data[i] = int(data[i]/2)
和其他类似的简单算法,但输出只是扭曲了,这表明WAV文件格式并不像我认为的那么简单。
推荐答案
无需调用子进程即可使用numpy
。代码示例:
import numpy
def audio_datalist_set_volume(datalist, volume):
""" Change value of list of audio chunks """
sound_level = (volume / 100.)
for i in range(len(datalist)):
chunk = numpy.fromstring(datalist[i], numpy.int16)
chunk = chunk * sound_level
datalist[i] = chunk.astype(numpy.int16)
注意:datalist
是您的音响阵列
要使用它,只需将您的声音数据传递给该函数并设置音量即可。
这篇关于使用PyAudio进行流媒体播放时修改音量的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!