python 實(shí)現(xiàn)音頻疊加的示例
如果你有兩條音頻合成為一條音頻(疊加,不是拼接)的需求,以下代碼可以直接使用,需要修改的地方我已經(jīng)標(biāo)出來(lái)了,有三處需要修改你的本地音頻的地址:輸入音頻1,輸入音頻2,輸出音頻3。
python3.8:
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import os
import wave
import numpy as np
import pyaudio
import librosa
import soundfile as sf
import scipy.signal as signal
import struct
# ok,音頻疊加!我這里4.wav和5.wav都是5s的音頻,還沒(méi)有測(cè)試時(shí)長(zhǎng)不同的音頻!
# 參考文檔:https://www.cnblogs.com/xingshansi/p/6799994.html
x,_ = librosa.load('D:/4.wav', sr=16000) #需要修改的地方:音頻1
sf.write('t1.wav',x,16000)
y,_ = librosa.load('D:/5.wav', sr=16000) #需要修改的地方:音頻2
sf.write('t2.wav',y,16000)
f1 = wave.open('t1.wav', 'rb')
f2 = wave.open('t2.wav', 'rb')
# 音頻1的數(shù)據(jù)
params1 = f1.getparams()
nchannels1, sampwidth1, framerate1, nframes1, comptype1, compname1 = params1[:6]
print(nchannels1, sampwidth1, framerate1, nframes1, comptype1, compname1)
f1_str_data = f1.readframes(nframes1)
f1.close()
f1_wave_data = np.frombuffer(f1_str_data, dtype=np.int16)
# 音頻2的數(shù)據(jù)
params2 = f2.getparams()
nchannels2, sampwidth2, framerate2, nframes2, comptype2, compname2 = params2[:6]
print(nchannels2, sampwidth2, framerate2, nframes2, comptype2, compname2)
f2_str_data = f2.readframes(nframes2)
f2.close()
f2_wave_data = np.frombuffer(f2_str_data, dtype=np.int16)
# 對(duì)不同長(zhǎng)度的音頻用數(shù)據(jù)零對(duì)齊補(bǔ)位
if nframes1 < nframes2:
length = abs(nframes2 - nframes1)
temp_array = np.zeros(length, dtype=np.int16)
rf1_wave_data = np.concatenate((f1_wave_data, temp_array))
rf2_wave_data = f2_wave_data
elif nframes1 > nframes2:
length = abs(nframes2 - nframes1)
temp_array = np.zeros(length, dtype=np.int16)
rf2_wave_data = np.concatenate((f2_wave_data, temp_array))
rf1_wave_data = f1_wave_data
else:
rf1_wave_data = f1_wave_data
rf2_wave_data = f2_wave_data
# ================================
# 合并1和2的數(shù)據(jù)
new_wave_data = rf1_wave_data + rf2_wave_data
new_wave_data = new_wave_data*1.0/(max(abs(new_wave_data)))#wave幅值歸一化
new_wave = new_wave_data.tostring()
p = pyaudio.PyAudio()
CHANNELS = 1
FORMAT = pyaudio.paInt16
# 寫(xiě)文件
framerate = 44100
time = 10
# 產(chǎn)生10秒44.1kHz的100Hz - 1kHz的頻率掃描波。沒(méi)用!
t = np.arange(0, time, 1.0/framerate)
wave_data = signal.chirp(t, 100, time, 1000, method='linear') * 10000
wave_data = wave_data.astype(np.short)
# 打開(kāi)WAV文檔
f = wave.open(r"D:\6.wav", "wb") # 需要修改的地方:輸出音頻
# 配置聲道數(shù)、量化位數(shù)和取樣頻率
nchannels = 1 #單通道為例
sampwidth = 2
data_size = len(new_wave_data)
framerate = 16000 # 設(shè)置為44100就是1s,設(shè)置為8000就是10s,只有16000才是5s是對(duì)的。這里還沒(méi)搞懂!
nframes = data_size
comptype = "NONE"
compname = "not compressed"
f.setparams((nchannels, sampwidth, framerate, nframes, comptype, compname))
# 將wav_data轉(zhuǎn)換為二進(jìn)制數(shù)據(jù)寫(xiě)入文件
# f.writeframes(new_wave)
for v in new_wave_data:
f.writeframes(struct.pack('h', int(v * 64000 / 2)))
f.close()
# 實(shí)現(xiàn)錄音,暫時(shí)用不到。
def record(re_frames, WAVE_OUTPUT_FILENAME):
print("開(kāi)始錄音")
wf = wave.open(WAVE_OUTPUT_FILENAME, 'wb')
wf.setnchannels(CHANNELS)
wf.setsampwidth(p.get_sample_size(FORMAT))
wf.setframerate(RATE)
wf.writeframes(re_frames)
wf.close()
print("關(guān)閉錄音")
以上就是python 實(shí)現(xiàn)音頻疊加的示例的詳細(xì)內(nèi)容,更多關(guān)于python 音頻疊加的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- 基于Python爬取素材網(wǎng)站音頻文件
- python爬取音頻下載的示例代碼
- python對(duì)批量WAV音頻進(jìn)行等長(zhǎng)分割的方法實(shí)現(xiàn)
- 音頻處理 windows10下python三方庫(kù)librosa安裝教程
- Python中操作各種多媒體,視頻、音頻到圖片的代碼詳解
- python將音頻進(jìn)行變速的操作方法
- Python3.7 讀取 mp3 音頻文件生成波形圖效果
- 利用Python小工具實(shí)現(xiàn)3秒鐘將視頻轉(zhuǎn)換為音頻
- python腳本實(shí)現(xiàn)音頻m4a格式轉(zhuǎn)成MP3格式的實(shí)例代碼
- 詳解python播放音頻的三種方法
相關(guān)文章
Python修改IP地址的常見(jiàn)方法總結(jié)
在網(wǎng)絡(luò)編程中,可能會(huì)遇到需要修改IP地址的情況,Python提供了一些功能強(qiáng)大的庫(kù)和模塊,可以幫助我們實(shí)現(xiàn)IP地址的修改操作,本文將介紹幾種常見(jiàn)的方法,以及如何使用它們來(lái)修改IP地址,需要的朋友可以參考下2023-12-12
Django應(yīng)用程序中如何發(fā)送電子郵件詳解
我們常常會(huì)用到一些發(fā)送郵件的功能,比如有人提交了應(yīng)聘的表單,可以向HR的郵箱發(fā)郵件,這樣,HR不看網(wǎng)站就可以知道有人在網(wǎng)站上提交了應(yīng)聘信息。下面這篇文章就介紹了在Django應(yīng)用程序中如何發(fā)送電子郵件的相關(guān)資料,需要的朋友可以參考借鑒。2017-02-02
Python轉(zhuǎn)json時(shí)出現(xiàn)中文亂碼的問(wèn)題及解決
這篇文章主要介紹了Python轉(zhuǎn)json時(shí)出現(xiàn)中文亂碼的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
python刪掉重復(fù)行之drop_duplicates()用法示例
Pandas的drop_duplicates()方法用于從DataFrame中刪除重復(fù)的行,這篇文章主要給大家介紹了關(guān)于python刪掉重復(fù)行之drop_duplicates()用法的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-08-08
Python tkinter模塊中類(lèi)繼承的三種方式分析
這篇文章主要介紹了Python tkinter模塊中類(lèi)繼承的三種方式,結(jié)合實(shí)例形式分析了三種繼承方式的實(shí)現(xiàn)方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-08-08
python中字符串類(lèi)型json操作的注意事項(xiàng)
這篇文章主要給大家介紹了python中字符串類(lèi)型json操作的一些注意事項(xiàng),文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-05-05
Python?Textual文本用戶界面庫(kù)使用原理探索
這篇文章主要為大家介紹了Python?Textual文本用戶界面框架使用原理探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-02-02

