前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python3+将2声道音频,分拆成1声

Python3+将2声道音频,分拆成1声

作者头像
py3study
发布2020-01-03 11:01:56
1.1K0
发布2020-01-03 11:01:56
举报
文章被收录于专栏:python3python3
代码语言:javascript
复制
现在是将双声道的音频分拆成单声道的。
同理可以将多声道的音频文件,转为1声道的音频文件。
注意新形成的音频文件的rate,需要与原音频的相同。
代码语言:javascript
复制
import os
import wave
import numpy as np
import pyaudio

file1 = os.path.join(os.path.abspath(os.path.dirname(os.path.dirname(__file__))), '音频文件/执迷不悟.wav')

f = wave.open(file1, "rb")

params = f.getparams()
nchannels, sampwidth, framerate, nframes = params[:4]
print(nchannels, sampwidth, framerate, nframes)  # 2 2 44100 11625348
# 读取波形数据
str_data = f.readframes(nframes)
f.close()

# 将波形数据转换为数组
wave_data = np.fromstring(str_data, dtype=np.int16)
wave_data.shape = -1, 2
wave_data = wave_data.T

wave_data_1 = wave_data[0]  # 声道1
wave_data_2 = wave_data[1]  # 声道2

w1 = wave_data_1.tostring()
w2 = wave_data_2.tostring()

# 实现录音
def record(re_frames, WAVE_OUTPUT_FILENAME):
    """
    :param re_frames: 是二进制的数据
    :param WAVE_OUTPUT_FILENAME: 输出的位置
    :return: 
    """
    p = pyaudio.PyAudio()
    CHANNELS = 1
    FORMAT = pyaudio.paInt16
    RATE = framerate  # 这个要跟原音频文件的比特率相同
    print("开始录音")
    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("关闭录音")

record(w1, os.path.join(os.path.abspath(os.path.dirname(os.path.dirname(__file__))), '音频文件/执迷不悟1.wav'))
record(w1, os.path.join(os.path.abspath(os.path.dirname(os.path.dirname(__file__))), '音频文件/执迷不悟2.wav'))

主要为了之后对两个音频的抵消与叠加进行处理做准备。 拆分后的音频,文件大小也只有原先的一半。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-09-23 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档