python-2.7 - 从文本文件生成波形声音

标签 python-2.7 audio mmap wave pyaudio

我已经使用以下命令从文本文件生成了频率声音序列:

import mmap
import math
import pyaudio

fh = open('/home/jay/Documents/try.txt', 'rb')

m = mmap.mmap(fh.fileno(), 0, access=mmap.ACCESS_READ)
ba = bytearray(m)

#sudo apt-get install python-pyaudio
PyAudio = pyaudio.PyAudio

#See http://en.wikipedia.org/wiki/Bit_rate#Audio
BITRATE = 16000 #number of frames per second/frameset.      

for freq in ba:
#See http://www.phy.mtu.edu/~suits/notefreqs.html
   FREQUENCY = 300 + freq #Hz, waves per second, 261.63=C4-note.
   LENGTH = 1 #seconds to play sound

   NUMBEROFFRAMES = int(BITRATE * LENGTH)
   RESTFRAMES = NUMBEROFFRAMES % BITRATE
   WAVEDATA = ''    

   for x in xrange(NUMBEROFFRAMES):
    WAVEDATA = WAVEDATA+chr(int(math.sin(x/((BITRATE/FREQUENCY)/math.pi))*127+128))    

   #fill remainder of frameset with silence
   for x in xrange(RESTFRAMES): 
    WAVEDATA = WAVEDATA+chr(128)

   p = PyAudio()
   stream = p.open(format = p.get_format_from_width(1), 
                   channels = 1, 
                   rate = BITRATE, 
                   output = True)
   stream.write(WAVEDATA)
   stream.stop_stream()
   stream.close()
   p.terminate()

(try.txt可以是您想要的任何文本文件)

但是它在频率声音之间有一些噪音,我该如何去除它并保存在.wave或.mp3文件中播放的所有频率的序列?
对不起,我还在学习,所以如果我不清楚我是否想问。
谢谢,
周杰伦

最佳答案

这里最大的问题是您在每个频率上打开/关闭音频流。

相反,保持流打开,您将获得更少的“点击”。这并不意味着您不会获得任何点击,这可能是因为处理时间有时太长并且流被中断了。最好的方法是使多线程生成和编写更具响应性,但这是另一回事了……

我还添加了.wav保存容量。我的输出文件名。效果很好。

固定代码(与Python 3一起运行)

import mmap
import math
import pyaudio,wave
import array


fh = open('K:\out.txt', 'rb')

m = mmap.mmap(fh.fileno(), 0, access=mmap.ACCESS_READ)
ba = bytearray(m)

#ba = [300,400,500,400,200]
#sudo apt-get install python-pyaudio
PyAudio = pyaudio.PyAudio

#See http://en.wikipedia.org/wiki/Bit_rate#Audio
BITRATE = 16000 #number of frames per second/frameset.

p = PyAudio()
stream = p.open(format = p.get_format_from_width(1),
               channels = 1,
               rate = BITRATE,
               output = True)

wf=wave.open("K:\wavout.wav","wb")
wf.setnchannels(1)
wf.setsampwidth(p.get_sample_size(pyaudio.paInt8))  # byte = 8 bits else trashed
wf.setframerate(BITRATE)


for freq in ba:
#See http://www.phy.mtu.edu/~suits/notefreqs.html
   FREQUENCY = 300 + freq #Hz, waves per second, 261.63=C4-note.
   print('freq '+str(FREQUENCY))
   LENGTH = 1 #seconds to play sound

   NUMBEROFFRAMES = int(BITRATE * LENGTH)
   RESTFRAMES = NUMBEROFFRAMES % BITRATE
   WAVEDATA = list()


   for x in range(NUMBEROFFRAMES):
    v = int(math.sin(x/((BITRATE/FREQUENCY)/math.pi))*127+128)
    WAVEDATA.append(v)

   #fill remainder of frameset with silence
   WAVEDATA+=[128]*RESTFRAMES

   b = array.array('B', WAVEDATA).tostring()

   wf.writeframes(b)
   stream.write(b)

#print data
wf.close()
stream.stop_stream()
stream.close()
p.terminate()

关于python-2.7 - 从文本文件生成波形声音,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39425919/

相关文章:

java - 是否可以使用Processing.exe中来自网络摄像头的实时手势控制音频?

database - 对返回图像、音频和所有重量级数据类型的 Web 服务的调用

Linux 上的 Python mmap 'Permission denied'

Python 动态创建自定义命名函数

linux - python : How to wait until disk activity subsides?

c - 如何在 Linux 中使用麦克风获取原始格式的语音

c - Linux mmap() 错误

c - 如何在不导致 Linux 内核崩溃的情况下访问 mmaped/dev/mem?

python - 使用 Python API 从 SoundCloud 流式传输歌曲

python - 无法使用 python 2.7 在 Mysql 中插入类型文本