亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

python 錄制系統(tǒng)聲音的示例

瀏覽:56日期:2022-07-01 16:04:54
環(huán)境準(zhǔn)備

python

wave pyaudio

wave 可以通過pip直接install,在安裝pyaudio時(shí),通過正常的pip install 直接安裝一直處于報(bào)錯(cuò)階段,后來想到可以通過輪子直接安裝。

在pypi提供的安裝包中有對(duì)應(yīng)的安裝包,注意,不僅僅是python2和python3的區(qū)別,python3的小版本也有點(diǎn)差別。可杯具的是,小主電腦里裝的是python3.8,后來想到還有一個(gè)網(wǎng)站可以安裝pythonlibs,找到對(duì)應(yīng)的版本后,下載下來。直接在文件所在目錄,或者在安裝中指定文件目錄中執(zhí)行安裝

pip install /c/Users/root/Downloads/PyAudio-0.2.11-cp38-cp38-win_amd64.whl代碼和運(yùn)行

def audio_record(out_file, rec_time): CHUNK = 1024 FORMAT = pyaudio.paInt16 # 16bit編碼格式 CHANNELS = 1 # 單聲道 RATE = 16000 # 16000采樣頻率 p = pyaudio.PyAudio() # 創(chuàng)建音頻流 dev_idx = findInternalRecordingDevice(p) stream = p.open(format=FORMAT, # 音頻流wav格式 channels=CHANNELS, # 單聲道 rate=RATE, # 采樣率16000 input=True, input_device_index=dev_idx, # 指定內(nèi)錄設(shè)備的id,可以不寫,使用win的默認(rèn)錄音設(shè)備 frames_per_buffer=CHUNK) print('Start Recording...') frames = [] # 錄制的音頻流 # 錄制音頻數(shù)據(jù) for i in range(0, int(RATE / CHUNK * rec_time)): # 控制錄音時(shí)間 data = stream.read(CHUNK) frames.append(data) # 錄制完成 stream.stop_stream() stream.close() p.terminate() print('Recording Done...') # 保存音頻文件 wf = wave.open(out_file, ’wb’) wf.setnchannels(CHANNELS) wf.setsampwidth(p.get_sample_size(FORMAT)) wf.setframerate(RATE) wf.writeframes(b’’.join(frames)) wf.close()

在使用默認(rèn)錄音設(shè)備時(shí),發(fā)現(xiàn)是話筒錄音,效果并不是太理想,所以就去查查能不能直接錄系統(tǒng)的聲音。

def findInternalRecordingDevice(p): # 要找查的設(shè)備名稱中的關(guān)鍵字 target = ’立體聲混音’ # 逐一查找聲音設(shè)備 for i in range(p.get_device_count()): devInfo = p.get_device_info_by_index(i) print(devInfo) if devInfo[’name’].find(target) >= 0 and devInfo[’hostApi’] == 0: # print(’已找到內(nèi)錄設(shè)備,序號(hào)是 ’,i) return i print(’無法找到內(nèi)錄設(shè)備!’) return -1

可以使用p.get_device_info_by_index()去查看系統(tǒng)有關(guān)聲音的設(shè)備,通過設(shè)置為立體聲混音就可以錄制系統(tǒng)聲音。

保存聲音

def save(fileName): # 創(chuàng)建pyAudio對(duì)象 p = pyaudio.PyAudio() # 打開用于保存數(shù)據(jù)的文件 wf = wave.open(fileName, ’wb’) # 設(shè)置音頻參數(shù) wf.setnchannels(CHANNELS) wf.setsampwidth(p.get_sample_size(FORMAT)) wf.setframerate(RATE) # 寫入數(shù)據(jù) wf.writeframes(b’’.join(_frames)) # 關(guān)閉文件 wf.close() # 結(jié)束pyaudio p.terminate()

保存聲音是通過上述代碼進(jìn)行保存,此處的_frames是個(gè)list,是通過每錄一個(gè)chunk(數(shù)據(jù)流塊),就把這一塊的數(shù)據(jù)添加進(jìn)去

然后只需要重新創(chuàng)建PyAudio對(duì)象,把這個(gè)list轉(zhuǎn)為字節(jié)串保存到文件中就可以了

問題

上述一般可以錄到系統(tǒng)聲音,但在執(zhí)行的時(shí)候發(fā)現(xiàn),并不能。

原因是:win的輸入設(shè)備中沒有配置立體聲混音

設(shè)置步驟:

在win的聲音調(diào)節(jié)出,右擊打開聲音設(shè)置 找到管理聲音設(shè)備 在輸入設(shè)備處啟用立體聲混音

就此,就完成了錄制系統(tǒng)聲音的需求

注意

上述操作,可以外放,可以插入3.5mm耳機(jī),但系統(tǒng)靜音和tpye-c耳機(jī)插入的時(shí)候不能錄到聲音

完整代碼

import osimport pyaudioimport threadingimport waveimport timefrom datetime import datetime# 需要系統(tǒng)打開立體聲混音# 錄音類class Recorder(): def __init__(self, chunk=1024, channels=2, rate=44100): self.CHUNK = chunk self.FORMAT = pyaudio.paInt16 self.CHANNELS = channels self.RATE = rate self._running = True self._frames = [] # 獲取內(nèi)錄設(shè)備序號(hào),在windows操作系統(tǒng)上測試通過,hostAPI = 0 表明是MME設(shè)備 def findInternalRecordingDevice(self, p): # 要找查的設(shè)備名稱中的關(guān)鍵字 target = ’立體聲混音’ # 逐一查找聲音設(shè)備 for i in range(p.get_device_count()): devInfo = p.get_device_info_by_index(i) # print(devInfo) if devInfo[’name’].find(target) >= 0 and devInfo[’hostApi’] == 0:# print(’已找到內(nèi)錄設(shè)備,序號(hào)是 ’,i)return i print(’無法找到內(nèi)錄設(shè)備!’) return -1 # 開始錄音,開啟一個(gè)新線程進(jìn)行錄音操作 def start(self): threading._start_new_thread(self.__record, ()) # 執(zhí)行錄音的線程函數(shù) def __record(self): self._running = True self._frames = [] p = pyaudio.PyAudio() # 查找內(nèi)錄設(shè)備 dev_idx = self.findInternalRecordingDevice(p) if dev_idx < 0: return # 在打開輸入流時(shí)指定輸入設(shè)備 stream = p.open(input_device_index=dev_idx, format=self.FORMAT, channels=self.CHANNELS, rate=self.RATE, input=True, frames_per_buffer=self.CHUNK) # 循環(huán)讀取輸入流 while (self._running): data = stream.read(self.CHUNK) self._frames.append(data) # 停止讀取輸入流 stream.stop_stream() # 關(guān)閉輸入流 stream.close() # 結(jié)束pyaudio p.terminate() return # 停止錄音 def stop(self): self._running = False # 保存到文件 def save(self, fileName): # 創(chuàng)建pyAudio對(duì)象 p = pyaudio.PyAudio() # 打開用于保存數(shù)據(jù)的文件 wf = wave.open(fileName, ’wb’) # 設(shè)置音頻參數(shù) wf.setnchannels(self.CHANNELS) wf.setsampwidth(p.get_sample_size(self.FORMAT)) wf.setframerate(self.RATE) # 寫入數(shù)據(jù) wf.writeframes(b’’.join(self._frames)) # 關(guān)閉文件 wf.close() # 結(jié)束pyaudio p.terminate()if __name__ == '__main__': # 檢測當(dāng)前目錄下是否有record子目錄 if not os.path.exists(’record’): os.makedirs(’record’) print('npython 錄音機(jī) ....n') print('提示:按 r 鍵并回車 開始錄音n') i = input(’請(qǐng)輸入操作碼:’) if i == ’r’: rec = Recorder() begin = time.time() print('n開始錄音,按 s 鍵并回車 停止錄音,自動(dòng)保存到 record 子目錄n') rec.start() running = True while running: i = input('請(qǐng)輸入操作碼:') if i == ’s’:running = Falseprint('錄音已停止')rec.stop()t = time.time() - beginprint(’錄音時(shí)間為%ds’ % t)# 以當(dāng)前時(shí)間為關(guān)鍵字保存wav文件rec.save('record/rec_' + datetime.now().strftime('%Y-%m-%d_%H-%M-%S') + '.wav')

以上就是python 錄制系統(tǒng)聲音的示例的詳細(xì)內(nèi)容,更多關(guān)于python 錄制系統(tǒng)聲音的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 91免费国产在线观看 | 护士和黑人做爰 | 欧美一级黄色片视频 | 黄色在线观看视频 | 亚洲欧美日韩精品 | 免费观看性欧美特黄 | 2021最新国产成人精品视频 | 中国a级淫片免费播放 | 亚洲操片 | 欧美一二三区 | 欧美aaa毛片免费看 欧美aaa级 | 三级精品视频在线播放 | 国产精品麻豆一区二区 | 黄色网址视频在线播放 | 日本xxwwwxxxx| 国产人免费人成免费视频 | 日韩爽爽视频爽爽 | 亚洲精品一区二区三区人妖 | 国产亚洲精品观看91在线 | 中文字幕亚洲另类天堂 | 大尺度一级毛片波多野结衣 | 久久久久国产精品免费 | 欧美精品国产一区二区三区 | 精品视频久久 | 国产一级内谢a级高清毛片 国产一级毛片大陆 | 98pao强力打造高清免费 | 视频一区 国产 | 免费黄色在线观看视频 | 99久久网 | 在线观看永久免费 | 国产短视频精品区第一页 | 中文字幕电影在线观看 | 色综合一区二区三区 | 色综合天天色综合 | 亚洲欧美日韩一区高清中文字幕 | 就去色综合 | 国产又黄又爽又色视频免费观看 | 黄色录相一级片 | 国产精品a v 免费视频 | 亚洲一级毛片在线播放 | 国产一区二区三区四区小蝌蚪 |